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“= USB Isolator 


Avoid interference and earth loops 


s= Vocal Annunciator 


How about making your next project speak? 


e Intelligent PC Fan Controller 


Control, monitor & configure a maximum of six PWM fans 


Radiation Meter Reloaded 
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Develop, assemble, solder 


Reflow-Controller LED Blinker 6 LEDs 
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board you 
need into the 
innovative new 
socket 
and its ready to work right away. 
Adding to your 


device was never So easy. 
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DEVELOPMENT TOOLS | COMPILERS | BOOKS WWW. | | bstock.com 


NOTE: Two 2x8 male headers are included in the package with each click board. 
By the time you read this, we might already have released more than 30 Click boards. Check out our website for more information. 
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Looking forward to being 
inundated (again) 


Here at Elektor we get the numbers all 
wrong occasionally. Although we’re 
perfectly able to calculate, say, bit time 
offsets to less than a microsecond using C, 
or Johnson noise levels in an NE553 opamp, 
we were horribly wrong with our guess- 
timate of the interest in our Embedded 
Linux article series. But happy to be wide 
off the mark! Let me explain. 

On Friday August 17, while working from 
my home on anew book called Labworx 

2: Mastering Surface Mount Technology, 

| wanted to correct a small bit of text 
somewhere on the elektor.com website 
using my administrator rights. Now | have 
a pretty slow PC at home, but this time the 
backoffice login procedure seemed to take 
so long I decided to do a small inspec 

tion round of my garden. On returning to 
my desk, | was greeted by error message 
-392a on the screen basically saying some- 
thing was overloaded. Then the telephone 
rang (it hardly ever does that) and our 
editorial secretary told me to sort-of- 
instantly write and email a short message 
telling customers that our webserver had 
been on 404 due to a flood of requests for 
an archive file that belongs with our recent 
Embedded Linux series. 

The problem was fixed almost instantly 

by moving the archive file to another area 
with capacity to spare. Apologies to all of 
you Linux fans and all other Elektor readers 
seeing 404s and having to wait a while 

for the file to become available. We have 
adapted the kernel (read all about it in 

this edition!), and fitted a pressure release 
valve on our webserver. 


Happy reading, 
Jan Buiting, Managing Editor 
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Colophon 
Who’s who at Elektor. 


News & New Products 
A monthly roundup of all the latest in 
electronics land. 


USB Isolator 

This little circuit provides electrical 
isolation of data lines and supply lines 
between the PC and the USB device. 


Embedded Linux made Easy (4) 

This month we delve deep into the 
various commands and options offered by 
the kernel. 


Thou Shalt Communicate! 

Here’s a Platino and Arduino compatible 
shield that packs Wi-Fi, Bluetooth and 
USB on a single board. 


AVR Software Defined Radio (6) 
In this instalment we discuss the time 
encoding format applied on the BBC 
Droitwich transmitter on 198 kHz. 


Picoammeter 

This little instrument was designed to 
cover those infinitesimally small currents 
between 0.1 pico-ampere to1 micro- 
ampere. 


E-Labs Inside: 

- Shifting RS485 Grounds 

- AVR reset-out-of-the-blue issue 

- E-pollution! 

- Your all-time favourite component 


Energy Harvesting 

with the LTC3108 & LTC3588-1 
Raymond’s pick of the month in terms of 
components 
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14 USB Isolator 


If your USB device ever suffers from noise caused by an earth loop or if you want 
to protect your PC against external voltages then you need a USB isolator. The 
circuit described here offers an optimal electrical isolation of the data lines as 
well as the supply lines between the PC and the USB device. 


28 Thou Shalt Communicate! 


You may have a Facebook account, but what about your oscilloscope? Does 
your multimeter tweet enough? Is your soldering iron linked in? You may be 
a non-communicative nerd but your bench power supply may be craving for 
social interaction. With the add-on board described in this article you can hook 
up anything to everything, with or without wires. 


54 Radiation Meter Reloaded 


Elektor’s Simple Radiation Meter is currently being used by many readers, 
mainly in making long-term measurements and in investigating weakly radio- 
active samples. There are several ways in which we can modify and improve the 
design, and we look here at a few examples. 


68 Intelligent PC Fan Controller 


With the help of the circuit described here you can actively control up to six 
fans, while the temperature can be measured in various places inside the PC 
case using anumber of sensors. A PC program is used to configure and monitor 
the fans, which communicates with the fan control board via a USB link. 
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Arduino on Course (2) 

No matter where your sensors are on the 

globe, you will be able to read them using 
Arduino functionality extended with GSM 
| GPRS. 


Radiation Meter Reloaded 

Elektor’s simple radiation meter keeps 
evolving, both at the front end (the 
sensors) and the user end (enter the PC!) 


Electronics for Starters (8) 

This series has met with great popularity 
with young & old. This month we tackle 
the basics of audio amplification. 


Vocal Annunciator 

Wouldn’t it be great to have a 
measurement system read out values 
aloud? Here’s how. 


Intelligent PC Fan Controller 

This circuit allows six (PC) fans to be 
controlled, configured and monitored 
with a good deal of intelligence. 


Retronics: Marconi Instruments 
TF801D/1 AM RF Signal Generator. 
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NEWS & NEW PRODUCTS 


New digital advanced bus converter lowers power 
consumption 


Ericsson has unveiled the first model in its second generation of digital Advanced Bus Con- 
verter (ABC) products. Based upon the FRIDA II platform, which was announced earlier this 
year, the Ericsson BMR456 3E Advanced Bus Converter delivers unprecedented performance 
to system architects who are developing equipment for ICT (Information and Communica- 
tion Technology) applications that require fast response time, tightly regulated intermedi- 
ate bus voltages and high efficiency at any point of operation to reduce power consumption. 
This new generation of fully regulated digital DC/DC converters is based on a 32-bit ARM 
microcontroller that embeds the family’s most advanced firmware to date. The FRIDA II 
firmware has been developed by Ericsson to guarantee the highest possible performance 
at any point of operation from low load to high load, and to handle line transients, such as 
those occurring in ATCA (Advanced Telecommunications Computing Architecture) applica- 
tions when, for example, switching from Feed A to Feed B. 
Designed to power telecom 
and datacom applications, the 
BRM456 is available in two 
input voltages ranges: 36 V to 
75 V, delivering output power of 
420 W; and 40 V to 60 V, deliver- 
ing output power up to 468 W. 
Output voltage can be adjusted 
across a range from 4.0 V to 
13.2 V via PMBus commands, 
making the BMR456 suitable 
for Dynamic Bus Voltage opera- 
tion resulting in the reduction of 
energy consumption when com- 
munication data traffic is low. 
In addition, taking full advantage of a highly optimized layout and firmware-optimized 
parameter switching to reduce power losses, the BMR456 delivers a typical efficiency of 
96.5% and exhibits flat curve behavior from 14% to 100% load, positioning the product 
as the most efficient Advanced Bus Converter in its category. Designed for flexibility and 
high-power applications, when connected in parallel, the Droop Load Sharing (DLS) ver- 
sion of the BMR456 telecom (36-75 V) and datacom (40-60 V) versions can deliver 756 W 
and 842 W, respectively. 
The BMR456 implements the FRIDA II firmware, called the ‘Ericsson DC/DC Energy Opti- 
mizer’, which combines advanced Ericsson Intellectual Property (IP) together with a series 
of industry-first functionalities to continually optimize switching parameters and reduce 
energy consumption to an absolute minimum. The firmware is not just limited to energy 
management, but includes an enviable number of features including the ability to han- 
dle input voltage transients with slew-rates of up to 0.5 V/us, while keeping the output 
voltage within +10% and ensuring that the output voltage does not trigger over-voltage 
protection. It also offers the highly efficient management of pre-bias start-up operation 
and a fully controlled shutdown process, avoiding voltage spikes that could cause an 
avalanche condition in the secondary-side synchronous rectification MOSFET, thereby 
contributing to improved reliability. 
The BMR456 meets the insulation requirements of EN60950, sustains an I/O isolation volt- 
age of 2250 VDC, and also offers an extensive set of capabilities and features such as: remote 
sensing; PMBus-configurable protection (over-temperature, over-current and over-voltage); 
configurable start/stop; precision delay ramp-up; voltage margining; configurable fault 
response; power good; and extensive power management programmability. 
The BRM456 is fully backward compatible with Ericsson’s previous generation of Advanced 
Bus Converters. The device’s I/O connector has been designed to guarantee full alignment 
and co-planarity using different soldering processes for both through-hole and surface- 
mount assembly. In addition to the mechanical benefits, the Ericsson Advanced Bus Con- 
verter footprint offers the necessary flexibility for further board design evolution and the 
addition of new features currently under evaluation within the ICT industry. 
www.ericsson.com/powermodules - 
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JTAG development system 
using WiFi 

The Debug Store is proud to announce 
the availability of the Macraigor Systems 
WiFiDemon in Europe. Priced at just £1475, 
the WiFiDemon is in stock and ready to ship. 
The WiFiDemon is Macraigor’s fastest and 
most versatile OCD interface device for use 
in the design, debugging and programming 
of microprocessor and microcontroller 
based embedded systems. 

The WiFiDemon can be connected to the 
host PC via a 10/100 BaseT Ethernet or WiFi 
connection allowing the developer to con- 





trol the debugging operation some distance 
from his desk — in fact he can be located 
across the globe! The WiFiDemon supports 
configurable JTAG/BDM clock rates from 
4.5 kHz to 24 MHz, allowing very fast code 
download and responsive debugging. 
The WiFiDemon is fitted with a 40 GB hard 
drive, two USB ports (to connect a mouse 
and keyboard) and a VGA port to connect a 
monitor. The development tools pre-loaded 
onto the hard drive can be run on the system 
allowing development work to be carried out 
locally — this makes it ideal for use in the field. 
www.thedebugstore.com - (120487-XI) 


RFID SMT antenna 

with comprehensive 
protection for automotive 
applications 


PREMO launches a new family of its TP0702 
standard, universally adopted by the indus- 
try. This format provides up to 50 mV/ 
App/m (for 7.2 mH) sensitivity which gives 
it the best sensitivity in this transponder 
size. The new TPO702U and TPO702UCAP is 
an SMD antenna for low frequency 20 kHz- 
150 kHz receiver applications. TPO702UCAP 
provide an upper and lateral side protection 
with co-polyamide polyhexamethylene pol- 
ymer walls, gamma radiated with high ther- 
mal stability (supports up to 290 ° C) and 
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mechanical resistance (exceeds 150 Mpa of 
mechanical strength). 

This antenna features a NiZn ferrite core 
with high surface resistivity (>10 MQ/mm) 
that provides a highly stable behavior (bet- 
ter than +3%) over a wide temperature 
range (-40 °C to 125 °C). 

The new TP0702UCAP is particularly suita- 
ble for applications such as TPMS (Tire Pres- 
sure Monitoring Systems) which requires an 
excellent performance under extreme con- 
ditions, according to AECQ200 and addi- 
tional requirements as EU regulations. 
PREMO offers four standard values, 2.38 
mH, 4.91 mH, 7.2 mH and 9 mH at 125 kHz. 





Other inductance values and frequencies, 
from 340 uH to 18.5mH, are available upon 
request. 

A surface mount (SMT) device, the new 
antenna allows easy use in the automated 
process of mounting circuit boards, thus 
eliminating any manual handling. 


www.grupopremo.com - (120487-IV) 


Rotary position sensor 
ensures accurate 
measurement at very 
high rotation speeds 


ams, a leading worldwide designer and man- 
ufacturer of high performance analog ICs for 
consumer & communications, industry & 
medical and auto-motive applications, today 
launched the AS5132, a magnetic rotary 
position sensor IC offering accurate angu- 
lar measurement even at very high rotation 
speeds. ams is the new name of austriami- 
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crosystems, following the 2011 acquisition 
of optical sensor company TAOS Inc. 
The AS5132 is a system-on-chip, combin- 
ing integrated Hall elements, an analog 
front end and digital signal processing in 
a single device. It is particularly well suited 
to industrial and automotive brushless DC 
(BLDC) motors, where it offers designers 
a small, robust and easily assembled posi- 
tion sensing solution. It is highly resistant 
to interference from stray magnetic fields. 
The new device improves on previous gen- 
erations of magnetic encoder by dynami- 
cally compensating for angle errors attrib- 
utable to propagation delay, which are most 
noticeable at high speeds. 
Error compensation is achieved through 
integrated pre-commutation functions. 
These are very easy to configure in the 
AS5132, and do not require external soft- 
ware routines to be executed, therefore 
unburdening host microcontrollers or elec 
tronic control units (ECUs). The configu- 
ration can be changed while the device is 
operating, in response to changes in oper- 
ating conditions such as variations in rota- 
tion speed. 
In addition, the advanced signal-processing 
circuitry in the AS5132 gives it an excellent 
propagation delay figure of <22 us, which 
means that even before pre-commutation is 
implemented the angle error is small. 
In combination, the small propagation delay 
and advanced pre-commutation deliver 
extremely accurate angle measurement 
even in motors rotating at speeds up to 
80,000 rpm: angle measurements are accu- 
rate to within +3° (maximum). This enables 
BLDC motor manufacturers to achieve high 
and constant levels of torque even in high- 
speed applications over the whole dynamic 
range. 
Other improvements introduced in the 
AS5132 include: 
e increased sensitivity to allow opera- 

tion in a magnetic field input as weak 

as 20 mT. This enables the sensor to be 

paired with a cheap ferrite magnet. 
e simplification of the interface for easier 

integration. 


17.22 EURO’ 


5 pcbs, 100mmk 100 mm 
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inclusion of an external clock mode, 
synchronizing sensor and controller 
systems. 

implementation of a 3 V interface mode 
(in addition to a 5 V mode) eliminating 
the need for a level shifter. 


When paired with a simple two-pole mag- 
net, the AS5132 provides absolute angle 
measurement at a resolution of 8.5 bits, or 
360 positions per revolution. This measure- 
ment is available as a serial output and as a 
pulse width modulated (PWM) signal. 

An additional U,V,W output can be used for 
block commutation in a BLDC motor; alter- 
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natively an incremental signal (ABI) is avail- 
able. In addition to the angle information, 
the strength of the magnetic field is repre- 
sented as a 5-bit value. 

The zero position can be set by software on 
the production line. This simplifies assem- 
bly, as the magnet does not need to be pre- 
cisely aligned with a fixed starting position. 
The AS5132 is suitable for contactless 
rotary position sensing, rotary switches 
(human machine interface), AC/DC motor 
position control and BLDC motor position 
control in automotive applications such as 
pump BLDC motors (stop-start system) and 
steering column BLDC motors. The AS5132 
is also particularly well suited to position 
sensing in double-clutch BLDC motors. 

A demonstration board for the AS5132 
rotary position sensor is available. Contact 
ams for the price. For further information on 
the AS5132 or to request samples, please 
visit Www.ams.com/eng/Products/ 
Magnetic Encoders/Rotary-Encoders/ 
AS5132 

(120487-X) 


d. 


Jacaltac: 


www.dms.com - 


*per piece, incl. VAT (23%) 
+ shipping costs e. g. Germany 10.89 EURO 


www.jackaltac.com 
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SPI real-time clock/calendars in smaller, 
10-pin packages 


Microchip recently announced the 
expansion of its stand-alone Real-Time 
Clock/Calendar (RTCC) portfolio with 
the new 10-pin, SPI MCP795XX fam- 
ily. These new devices offer many of 
the same features as the larger 14-pin 
MCP795WxXxX family, including supe- 
rior timekeeping performance. 

Reducing overall component count in 
the system and eliminating the user 





programming costs for a serial ID i Microchip wit A rasa E Uae wea 
make the MCP795XX RTCC family an 
ideal choice for the handheld, wireless | csaa cass Vee 


Alam Catt 


and consumer markets. By including 


64 bytes of SRAM, 2 Kbits of EEPROM | ninin 
and a 128-bit Unique ID, which can be e A 
ordered blank or preprogrammed with | ` eat 


a MAC address, extra memory devices 
may not be needed. Utility power 
meters, manufacturing equipment, 
radios, GPS and hospital instrumenta- 
tion applications that need accurate 
time over a broad temperature range will also benefit from the very wide digital trim- 
ming range, which can compensate up to 22 seconds per day for crystal frequency drift. 
Digital trimming improves the timekeeping accuracy of RTCCs, and a wide digital trim- 
ming range provides customers with high accuracy over a large temperature range. 
Accurate timekeeping is also supported at a decreased power-consumption level, 
because digital trimming is maintained when the MCP795XxX is operating from backup 
power on the VBAT input. Additionally, these devices join the industry’s only portfolio 
to distinctively offer a battery-backed RTCC with both power-fail and power-restore 
timestamps plus three types of non-volatile memory: EEPROM, SRAM and a Unique ID. 
When the time and duration of power failures need to be logged, the MCP795XX fam- 
ily can accomplish this without adding any circuitry by using the on-chip power-fail 
timestamp feature, which is not offered by any other SPI RTCC on the market. With 
long battery life at a premium, applications such as wireless, portable communications, 
security and automotive can benefit from the 5 MHz SPI bus and millisecond alarm. This 
high-resolution alarm output provides a greater degree of control over the duty cycle 
needed to support longer MCU sleep and power-down modes. 
http://www.microchip.com/get/oCX3 - (120532-I) 





Lossless Extended Range 
Synchronized (LXRS™) 
Wireless Sensor Networks 


MicroStrain’s new “lossless” wireless com- 
munication protocol (patent pending) sup- 
ports scalable networks of high speed sen- 
sor nodes without data loss due to tempo- 
rary radio frequency (RF) fading, multipath, 
or interference. 

MicroStrain’s users have previously enjoyed 
a typical RF packet success rate of 99% — 
not bad. But now, with MicroStrain’s new 
LXRS “lossless” protocol, wireless sen- 
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sor networks can deliver 100% reliable 
data throughput under most operating 
conditions. 

The new LXRS™ Wireless Sensing Sys- 
tem (microstrain.com/what-is-LXRS?) 
includes: 

Lossless wireless communication protocol 
providing 100% packet success rate under 
most operating conditions 

Extended Range radio link to 2 kilometers 
Scalable wireless sensor networks support- 
ing continuous, burst, and hybrid sampling 
modes 

Time Synchronized to +32 microseconds 
The LXRS™ Wireless Sensing System works 


by leveraging an advanced bi-directional 
radio communication protocol. When 
data are received without errors by the 
WSDA base station, the WSDA sends an 
acknowledgement that these packets were 
received. Data that are not acknowledged 
remain within each LXRS sensor node’s non- 
volatile memory for scheduled re-transmis- 
sion without reducing the overall system 
bandwidth. 

Each wireless node in the network has its 
own precision timekeeper and maintains 
time synchronization to within +32 micro- 
seconds. Data are time-stamped by each 
node at the time of analog-to-digital (A/D) 
conversion. Therefore, even when re-trans- 
mitted, all data are accurately time stamped 
and aggregated into a master file using time 
as a unifying variable. 

This enables highly reliable data collection 
from scalable networks of wireless strain, 
acceleration, torque, force, temperature, 
etc. to be collected without loss of informa- 
tion. This is particularly useful when work- 
ing in harsh operating environments, when 
the system may be subject to periodic RF 
interference, and when the experiment or 
test is very difficult to set-up or very expen- 
sive to replicate. 

Synchronized data collection, combined 
with robust and reliable LXRS data acquisi- 








MicmStrain Lossless Extended Range, 
Synchronized Wireless Sensor Networks 


tion, allows users to select lower sampling 
rates and reduced RF power levels. This 
leads to longer battery lifetimes and also 
enables energy harvesters to be used in 
place of primary batteries. 


www.microstrain.com - (120532-Il) 
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DIAMEX PROG-S UTD 2052 CEL CONNECTING THE WORLD 
(~ £16,90) (~ £235,01) 
Neutrik Speaker 

Multi-talented ISP programmer e For professional stage / loudspeaker technology 
for three programming modes 2-channel storage oscilloscope e Easily lockable through Quick-Lock System 
Programs the popular AVR, STM32, NXP Storage oscilloscope with excellent performance data, extra e Touch-proof contacts 
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and Low-Bat-Display. UG 88U-C59 (~ £0,22) RG59 


(~ £15,68) 





RMS measurement 
Extremely economical ISP Programmer for ATMEL Diode test A PA core 
processors that can be programmed using the simple Through buzzer es 











e 
e 
e 
SPI interface. Noteworthy is the designated on-board e Data-Hold eMIN/MAX for example 
processor with specifically developed firmware that e REL function PFL 10 (~ £0,06) 10-pole 
enable extremely fast programming cycles. e Peak value function . : 
; ; 5 USB interface TTT eee 
AVR STK 500, AT Mega, AT Tiny, AT 90 i 
Safety: Cat || 600 V, 5 : 
Tee CAT i 300 V Sor, as en ag sk 
DIAMEX ALL AVR (~ £62,84) for example 
` Tee D-SUB BU 09 (~ £0,09) 
(~ £23,19) eE- AC voltage tester PeakTech? D-SUB BU 25 an) 
= ar É 90-1000 v AC TTT eee 
DIAMEX ALL-AVR is a USB programming adapter All D-Sub solid metal hoods 
that can be used for programming the popular AVR- e Safety: EN 61010-1, CAT Ill 1000 V http://rch.|t/4Z = a 
Controllers by ATMEL. ° ie signal „=æ “| for example = 
e AT 90, AT Mega, AT Tiny, ATX Mega Ane Rater oe KAPPE EMV 09 (~ £1,49) 
i KAPPE EMV 25 (~ £1,53) 





PEAKTECH 1030 (~ £7,82) 


For consumers: The statutory right of withdrawal for consumers shall apply. All stated prices in € include the legal value added tax, ex works Sande, plus forwarding charges for international payment via 
the entire shopping cart. Our general terms and conditions shall apply exclusively (under www.reichelt.de/agb in the catalogue or on request). Subject to prior sale. All product tw 
names and logos are property of the respective manufacturers. Images can be similar. Subject to misprint, errors and changes in prices. PayPal 


reichelt elektronik GmbH & Co. KG, Elektronikring 1, 26452 Sande (HRA 200654 Oldenburg) Daily rates! - Price level: 15.8.2012 





NEWS & NEW PRODUCTS 


Low-pressure-drop 
digital flow meter 


Swiss sensor manufacturer Sensirion is 
launching the new digital SFM3000 mass 
flow meter for high-volume applications in 
medical devices, process automation and 
burner control. The flow channel is designed 
to achieve a very low pressure drop of less 
than 3mbar through the sensor element. 
The flow meter bi-directionally measures 
the flow of air and other non-aggressive 
gases at rates up to 200 slim with high accu- 
racy and very high speed. It outputs a 14-bit 
digital signal at a 2 kHz update rate. The sig- 
nal is internally linearized and temperature 
compensated. Furthermore, the new mass 




















flow meter operates from a 5 Vdc supply 
voltage and features a digital 2-wire inter- 
face, making it easy to connect directly toa 
microcontroller. 

The outstanding performance of the 


SFM3000 gas flow sensor is based on Sen- 
sirion’s patented CMOSens® Technology, 
which combines the sensor element, signal 
processing and digital calibration on a tiny 
microchip. Gas flow is measured by a ther- 
mal sensor element to provide an extended 
dynamic range and enhanced long-term 
stability compared to other flow measuring 
technologies. Thanks to the proven CMOS- 
ens® technology, the flow meter is suited 
for high-quality mass production and is the 
ideal choice for demanding and cost-sensi- 
tive OEM applications in medical ventilation 
and anesthesia, as well as process automa- 
tion and burner control. 
www.sensirion.com/en/sfm3000 - (120532-V) 


The Electronics Maze Solved 


In addition to the annual Jumbo edition of Hexadoku, Elektor’s 
July & August 2012 edition also featured a rather different type 
of puzzle: the Maze of the Lost Electronics Technician. Our readers 
were faced with a maze consisting of passive components: diodes, 
zener diodes, resistors, coils, capacitors and the odd pushbutton. 
The challenge was to find the input to which 20 volts had to be 
applied to make a current flow at the output. 


Hundreds of readers entered the maze and managed to find the 
way out successfully. The correct solution was: input 2. 


The winner of the 
Electronic Workstation — Desktop worth £800 
anda 
Protostation Advanced Breadboard worth £125, 


both kindly sponsored by Matrix Multimedia, is: 


Evan Wasserman 
of Lakewood, New Jersey, USA. 


Evan’s estimate of the total number of correct solutions received 
was closest to the actual figure. Congratulations, your prizes are 
on the way to you. 


(120537) 
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From simple to complex applications, nothing can handle your measurements more 
effectively than the National Instruments data acquisition platform. Whatever your 
budget, channel count, or performance requirements, its unparalleled high-performance 
I/O and ability to increase productivity through software measures up to the challenge. 
This combination can help you balance performance and investment to deliver precision 
accuracy that is scalable and always trustworthy. 

Designed for Performance. 
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COMPUTERS 


USB Isolator 


Avoid interference and earth loops 












By Raymond Vermeulen (Elektor Labs) 


If your USB device ever 
suffers from noise caused 


by an earth loop or if you MA TEN > NGE T Beroa 


aay 
aig a 


a 
P l 


want to protect your PC 


against external voltages “ea 
Pees tht C9 
ATI 


then you need a USB isolator. 
The circuit described here offers 
an optimal electrical isolation of 
both the data lines as well as the 
supply lines between the PC and the 
USB device. 


ic seman ie a ated onan as 
lier design for a portable oscilloscope for S - ecifications 


Android. During the development of that e Electrically isolated data and power supply lines 
project we also encountered the problems e Configurable data rate of 1.5 Mbit/s or 12 Mbit/s 
of earth loop noise when a charger or PC e Power for the device side can be taken from an extra USB host connection or an external 


was connected. But what was the best point 
where to introduce isolation, the digital USB 
connection or the analogue section? After 
some serious analysis we came to the con- 
clusion that it was better to isolate the USB 
bus rather than the analogue part. 


AC power adapter (5 V/min. 0.5 A) 
e Transformer isolation = 1500 Vac for1 min 
e ADuM3160 isolation = 565 Vpeak for 50 years 
e Maximum output current lout = 500 MA @ 5 V 


A popular chip from Analog Devices, the 
ADuM3160, was chosen to provide the iso- 
lation of the data lines. It supports both Low 
and Full speed USB connections. A flyback 
converter with a LT3575 as controller was 
used to isolate the power supply. 


Special IC 

The ADuM3160 [1] used in this project, and 
its bigger brother the ADuM41 60, are, as far 
as we know, the only dedicated USB isola- 
tors currently available in the marketplace. C 
These chips can also be found inside most 
commercially available USB isolators. The 
chips support Low-speed (1.5 Mbit/s) and Figure 1. Internal block diagram of the ADuM3160. A number of monolithic transformers 
Full-speed (12 Mbit/s) USB. According to provide the electrical isolation between the two sides of the device. 
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Figure 2. The circuit diagram for the USB isolator. At its heart is a special IC from Analog Devices (IC2), 
which provides electrical isolation of the USB signals. 


Analog Devices the reason why High-speed 
(480 Mbit/s) USB is not supported is due to 
the fact that there are currently no digital 
isolators available that can operate reliably 
at these high data rates. There are currently 
no plans to introduce a new IC for this. 


In Figure 1 you can see the internal block 
diagram for the IC. The combination of 
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high-speed CMOS technology with air core 
transformers (the iCoupler technology 
from AD) results in an outstanding isolation 
between the primary and secondary sides. 
To detect the direction of the data flow 
over the USB lines (in order to turn on the 
appropriate output buffers) the IC deter- 
mines the direction based on the contents 
of received data packets. The propagation 


delay (the time taken for the received sig- 
nal to appear at the output) is fairly small 
despite the stringent isolation require- 
ments, and is comparable to that found in 
a standard USB hub. 


Circuit diagram and power supply 


You may wonder why the power supply is 
specifically mentioned in the heading for 
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COMPONENT LIST 


Resistors 

(1% 0.1W, SMD 0603, unless otherwise 
shown) 

R1 = 1kQ 1% 0.5W (SMD 1206) 

R2 = 33kQ 

R3 = 80.6kQ 

R4 = 6.04kQ 

R5 = 200kQ 

R6 = 90.9kQ 

R7,R8 = 28.7kQ 

RO,R10,R11,R12 = 240 

R13,R14=4.7kQ 


Capacitors 

C1,C2 = 10nF 16V X7R (SMD 0603) 

C3 = 220nF 50V X5R (SMD 0603) 

C4,C5,C6 = 120uF 6.3V (Nichicon RFS- 
0J121MCN1GS, type C) 

C7,C8,C9,C10,C11,C12 = 100nF 25V X7R 
(SMD 0603) 

C13,C14,C15,C16 = 10uF 6.3V X5R (SMD 
0805) 


L418 c13 


Ne’ 


mj: x 
L5 


this section. It’s because it plays such a sig- 
nificant role in this design. The ADuM3160 
can only provide isolation for the data lines 
and not for the supply line. You could pro- 
vide each side of the IC with its own, sepa- 
rate power supply. 


In this case (see Figure 2) we decided to 
add an isolated switching power supply to 
the board. This not only provides power for 
the other half of the IC, but also provides 
the maximum permitted current for the 
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Inductors 

L1,L2,L3,L4,L5,L6,L7,L8 = ferrite inductor 
33Q@100MHz (SMD 0603) e.g. Murata 
BLM18PG330SN1D 

L9,L10 = 1H 1.2A (SMD 1007) e.g. Taiyo 
Yuden CB2518T1ROM 


Semiconductors 


D1 = PMEG3050BEP (NXP) (SOD-128) 

D2 = PMEG6010CEH (NXP) (SOD-123f) 

D3,D4 = 5.6V 3W zener diode 

IC1 = LT3575EFE#PBF (LT) (TTSOP-16) 

IC2 = ADUM3160BRWZ (AD) (SOICW-16) 

IC3 = NCP380HSN10AAT1G (On Semiconduc 
tor) (TSOP-5) 

1C4,1C5,IC6 = NCP380HSNO5AAT1G (On Semi- 
conductor) (TSOP-5) 

IC7,IC8 = TPD2EUSB30ADRIR (TI) (SOT-3) 


Miscellaneous 


$1,S2 = slide switch with changeover contact 
(e.g. C&K Components PCM12SMTR) 


Figure 3. 

The dimensions of the 
board were chosen to fit 
inatype 1593KBK case 

from Hammond. 


USB device connected to it (which is also 
completely isolated from the input!). 

To obtain the required 500 mA at 5 V from 
the output we have chosen a LT3575 fly- 
back converter from Linear Technology [2]. 
Remarkably this IC doesn’t require an opto- 
coupler for a feedback signal. The converter 
operates in a so-called boundary mode, 
where the information regarding the out- 
put voltage of the secondary inductor is fed 
back to the primary inductor. This works as 
follows: 





K1,K2 = USB mini-B-connector, PCB mount 
(e.g. On-Shore USB-M26FTR) 

K3 = DC adapter connector, 1.35 mm (e.g. CUI 
P]-014DH-SMT) 

K4 = USB-A connector, PCB mount (e.g. FCI 
87583-2010BLF) 

TRI = transformer 3:1, 25 uH (e.g. Würth 
750310471) 

Case, Hammond type 1593KBK 

2 self tapping screws, cross head, 4x6.4mm, 
DIN7981 

PCB # 120291-1 or 

assembled and tested board and case, # 
120291-91 


cos i Peay, 
3 = 


T! 
wi 
|| 
sl 


j 


When the power switch in the converter 
turns off, the voltage rises to a level that is 
equal to: 


Vetpk = (Vout + Ve + Isec X ESR) x Nps 


where 

e V; = voltage across diode D1; 

“ Isgc = current through the secondary 
winding; 

e ESR = total impedance of the secondary 
side; 
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e Nps = turns ratio of the primary 
and secondary windings of the 
transformer. 


In conjunction with the tempera- 
ture compensation this provides 
enough information to regulate the 
output voltage. One consequence of 
this method is that the switch has to 
be turned off for a certain minimum 
amount of time during each cycle, to 
give the IC sufficient time to process 
the feedback information. 

An off the shelf transformer from 
Wurth was chosen, which is a small 
potted type for SMD mounting. 

The data lines are protected from high 
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USB ISOLATOR 


loaded from the Elektor website [3] 
accompanying this project. 


Usage 

It is very easy to use the USB isola- 
tor. First, set the required speed with 
switches S1 and $2. 


Both of these should always be set to 
the same speed! 


Normally a USB device can let the host 
know at which speed it operates via 
a pull-up resistor on one of its data 
lines. This isn’t possible with this iso- 
lator and the speed has to be set man- 
ually via switches (this is also the case 








input voltages by IC7 and IC8. These 

are two-channel ESD protection ICs 
(TPD2EUSB30A) from TI (this part 
would also be suitable for USB3 data 
lines). The dimensions of this IC are so 
small (1 x 1 mm!) that it can easily be put 
between the data lines on the PCB. 

All power supply connections are pro- 
tected against overloading with the help 
of high-side power distribution switches 
(NCP380) from ON Semiconductor. These 
ICs include a detection and control circuit 
with a P-channel MOSFET that limits the 
output current when it exceeds a preset 
value. Two different types of the NCP380 
have been used in this circuit: IC4, 5 and 6 
limit the current to 0.5 A, IC3 to 1 A. These 
provide optimum protection to al inputs 
and outputs (both USB and supply) against 
(almost) all possible types of overload. 

In this way, the USB ports are limited to 
500 mA and the 5 Vpc connection is limited 
to 1000 mA. A connected USB device always 
has 500 mA available to it, which doesn’t 
quite conform to the official USB standards. 
Initially, the limit should really be 100 mA. 
It should be increased to 500 mA only after 
the device has announced itself to the host 
and requested the current increase. How- 
ever, in practice it seems that you can nor- 
mally get 500 mA from a USB port on your 
PC without the need for any requests. 

In order to keep ripple to a minimum at the 
primary and secondary side of the switch- 
ing power supply, we’ve added LC filters to 
both sides (L9/C4 and L10/C13). The ripple 
currents through capacitors C4 and C5 are 
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Figure 4. Print this out and stick it to the top of the 


case for the professional look. 


very large, which you have to keep in mind 
when you select the types for these. It is 
best to use capacitors with the lowest pos- 
sible ESR. To keep the turn-off spike at the 
primary side of the supply within manage- 
able levels, an RCD snubber network has 
been added, consisting of R1, C3 and D2. 


Construction 

For a circuit that has so many special ICs 
(all SMD) it is a ‘must’ to have a thought- 
fully designed board layout. In Figure 3 
you can see the board that was designed 
in the Elektor Labs. It is of course possible 
to obtain this board separately and pop- 
ulate it yourself. However, since several 
components are very tricky to solder due 
to their size, and some are also not easily 
obtainable, Elektor has made a fully popu- 
lated board available, including the case. 
All you need to do is to add a few holes for 
the connectors and slide switches in the 
two side panels of the case. To be on the 
safe side, the two tags of K4 that come 
through the board should be soldered 
using an ordinary soldering iron. The 
board can then be fixed inside the case 
using the two screws provided. 


The drawing in Figure 4 can be copied and 
stuck to the top of the case. The original 
design for the drawing can also be down- 


for most commercially available USB 
isolators). 


Connect the ‘host’ (in most cases this 

is your PC) to K1 (HOST SIDE: USB/ 
PWR+DATA) and the isolated USB device to 
K4 (DEVICE SIDE: USB/PWR+DATA). If the 
device needs more than 300 mA we sug- 
gest that you connect an extra USB cable to 
K2 (USB/PWR) or connect a regulated 5 V 
power adapter (min. 500 mA) to power sup- 
ply connector K3 (5 Voc). 


We recommend that you don’t use this 
project in situations where there may be 
voltage differences between the host and 
device side that are greater than the AC line 
voltage. You should also not subject the 
device to high voltage differences between 
the host and device side for extended peri- 
ods of time, because the isolation can 
deteriorate over time if the components 
are continuously exposed to high voltage 
differentials. 

(120291) 


Internet Links 


[1] www.analog.com/static/imported-files/ 
data_sheets/ADuM3160.pdf 


[2] http://cds.linear.com/docs/ 
Datasheet/3575f.pdf 


[3] www.elektor.com/120291 
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MICROCONTROLLERS 


Embedded Linux 


Made Easy (4) 





A look at the kernel 


By Benedikt Sauter [1] 


GNU/Linux provides interfaces and applications 
for devices that we are used to seeing on desktop 
computers and servers. Much of this transfers to 


the embedded domain, where Linux relieves the 


programmer of a lot of work by handling networking, 


USB, Bluetooth and more without the need to write 
complex dedicated C programs. And as we shall see, 
using a modern operating system brings many other 


benefits too. 


In the previous instalments in the series we have looked at how the 
toolchain, the kernel and bootloader, and a standard file system can 
be got up and running. One aim of the series is to show developers 
what is happening ‘under the bonnet’, for example in how devices 
and processes are implemented. In this instalment we will first look 
at what advantages there are in using an operating system when 
compared to driving hardware at the ‘bare metal’ level. 

What is the essence of an operating system? At its heart it consists 
of a collection of all the software needed to run specially-written 
applications in parallel with others. The distinction between ‘nor- 
mal’ firmware and operating-system-based firmware is, however, 
somewhat blurred. It is common enough for normal firmware to 
include a clean interface to the hardware layer to provide com- 
monly-wanted functions, for example in memory management; 
and often there will be a small scheduler to divide the processor’s 
attention between different programs. Together these already form 
the beginnings of what might be called an ‘operating system’. 


A typical operating system 

There are of course many books on the subject of operating sys- 
tems [2]. Here we shall only take a broad overview of the main 
components: 


e Device management 

e Process management 

e Memory management 

e File management 

e User and permissions management 


In the embedded world device management is usually a particularly 
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important aspect. The operating system must present peripherals 
and hardware to applications in such a way as to simplify their use 
as far as possible. This is done using device drivers. The operating 
system is also responsible for handling all the details behind allow- 
ing several programs to run simultaneously, all wanting access to 
SD cards, network interfaces and so on. 

In the simplest programming model, an application running under 
an operating system is a single, independently executable process. 
A process has its own virtual address space, ensuring that it cannot 
disturb other processes. Processes are centrally managed via the 
process table, and each has its own ‘process control block’ [3] which 
typically includes space for temporary storage of processor register 
contents and other important variables: 


e Program counter 

e CPU registers 

e Stack pointer 

“ Status of open files 

e Process state 

e Other status information 


When we launch our ‘hello world’ program the kernel loads the 
application and creates a new process. A new process is always cre- 
ated on the basis of the current one, and inherits the user permis- 
sions associated with it. The command 


ps -ejH 


will display the current set of processes in the system in a tree struc- 
ture. At the root of the tree is the first process launched by the ker- 
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nel, invariably called ‘/sbin/init’. Starting this process is one of the 
first things the kernel does when booted. 

As developers we are particularly interested in the following fea- 
tures of an operating system: 


e The interface for device drivers 

e The file system for programs and data 

e Launching and executing programs 

e Shared use of libraries by different programs 

e Access to input and output ports 

e Transferring working memory to non-volatile memory 
e Memory management for applications and processes 
e Process management 


Let us start with device management. 


Configuring the kernel 

Which interfaces and peripheral blocks of the embedded processor 
we need will depend on the application. The Linux kernel is designed 
in a modular fashion, which results in the developer having very 
fine control over its settings and in particular over what drivers and 
mechanisms will be included in the kernel. It is also subsequently 
possible to load other components dynamically. The best way to 
see how this is done is to look directly in the kernel source code. So, 
switch to the kernel source code tree: 


cd ElektorLinuxBoardDownload 20120509 
cd linux-2.6.33-lpc3131x 

and invoke the kernel configuration menu: 
make menuconfig 


The main menu (Figure 1) should immediately appear. If it fails to 
appear, one possible cause is that the libraries for displaying con- 
sole-style menus are missing. They can be installed on our Ubuntu 
system by typing: 


sudo apt-get install lLibncurses5-dev 


From the main kernel configuration menu it is possible to enable or 
disable any of its features and device drivers at will. For the beginner 
it will not always be immediately obvious where within the menu 
structure a particular option might be hiding, but with a bit of prac 
tice it soon becomes familiar. 

An alternative to using the menu is to go straight to the config- 
uration file ‘.config’ in the kernel source directory (linux-2.6.33- 
lpc3131x) and edit it by hand. (The full stop at the start of ‘.config’ 
indicates that it is normally a ‘hidden file’.) However, it is usually 
more convenient to use the interactive menu. Before changing the 
configuration it is a good idea to make a backup copy of the current 
configuration file. 
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Figure 1. Main kernel configuration menu. 


cp .config config backup 


Newcomers to Linux often ask where good documentation can be 
found. The best documentation for the kernel is in the kernel source 
itself. It is also possible to click on ‘help’ at any time in the menu to 
find information on a particular item, or you can browse through 
the ‘Documentation’ directory (at the top level of the kernel source 
tree) to look for information on a particular topic. 


As Figure 1 shows, the menu items are sorted into groups. At the 
top are the general kernel settings, and then follow settings for the 
device drivers and file systems, and finally items relating to cryp- 
tography and security. 


General setup 

The menu item ‘General setup’ covers the basic characteristics of 
the kernel, including, for example, whether there is any swap space, 
how memory is managed and how internal communications are car- 
ried out. There are also settings relating to the kernel image itself, 
optimisations for small systems, statistics, tools and much more 
besides. The more you find out about the Linux kernel, the more 
handy features you discover: there are only a few people who can 
lay claim to understanding it completely! 


Enable loadable module support 

Another good feature of Linux is that the kernel can be extended, 
while it is running, by simply adding extra modules. The kernel 
configuration menu lets you decide whether a particular feature 
or driver should be permanently built into the kernel code or com- 
piled as a module: an ‘M’ before a menu item means that the feature 
will be compiled as a module, whereas an asterisk before an item 
means that it will be built in permanently. If you want to be able 
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to support a wide range of different devices, building all the driv- 
ers into the kernel can make it unwieldy: it is better to compile the 
drivers as modules and load them manually or let the kernel load 
them automatically. 


Enable the block layer 

The kernel distinguishes between two types of device: character 
devices and block devices. A character device sends and receives 
messages and other data one character at a time; a block device 
always does so in complete blocks. Typical character devices include 
consoles and UART interfaces; block devices include hard disks and 
memory cards such as MMC and SD cards. If no block devices are 
needed (as is possible for some embedded systems) some memory 
space can be saved by disabling the ‘block layer’. 


System type 

Some kernel features depend on the type of processor being used. 
For example, it may be desirable to enable or disable caches or 
memory management units. This menu item lets you specify (as 
far as is possible) the processor type: if your particular processor is 
not listed, you will need to find a patch or suitable ‘board support 
package’ (or write it yourself). 


Bus support 
Here it is possible to enable support for typical PCtype buses. In our 
case only the PCMCIA option is available. 


Kernel features 

This item is very kernel-specific: you can specify what binary inter- 
face convention is to be presented to programs and other miscella- 
neous features, such as displaying processor load via the blink fre- 
quency of an attached LED. 


Boot options 

How the kernel is started up depends in the case of the Elektor Linux 
board chiefly on the bootloader. The main interface between the 
bootloader and the kernel is the so-called ‘kernel command line’. 
This command allows the bootloader to pass various parameters to 
the kernel that can subsequently be examined by it or by other pro- 
grams. The menu item allows you to specify that a given different 
command line should be used instead. Alternatively, it is possible to 
compile the kernel so that it can be run directly from flash storage. 


CPU Power Management 

These days processors offer an ever wider range of features to sup- 
port efficient power management. The kernel has to be properly 
configured to allow applications to take full advantage of these 
features. 


Floating point emulation 

This kernel configuration menu option allows you to configure it so 
that it takes responsibility for floating-point calculations or so that 
hardware support is used. At least one of these alternatives must be 
selected to allow programs to be run. 
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New version of the Elektor Linux board 


Demand for the Elektor Linux board has been truly overwhelming! 
Because of the large number of orders we have received the next 
production batch has had to be made rather sooner than expected. 
Unfortunately the DRAM chip in the BGA package has a lead time 
of some 20 weeks, and so we decided to change the layout to ac 
cept a TSOP54 device. The new memory has the same capacity as 
the old one but requires a supply voltage of 3.3 V instead of 1.8 V. 
The upper picture shows the original version of the board with the 
BGA memory chip, while the version in the middle picture has the 
TSOP54 device fitted. Since the beginning of July we have been de- 
livering version ‘1.1 blue’ of the board, in which the now redundant 
1.8 V voltage regulator circuitry is removed. You can easily identify 
the most recent version of the Elektor Linux board by its blue colour. 
The corresponding circuit diagram is shown here. 
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User space binary formats 

Programs and applications are compiled using the toolchain (see 
the previous instalment in this series). Normally, for a Linux system, 
the toolchain will produce either a .elf file (“executable and linka- 
ble format’, corresponding roughly to a .exe under Windows) or an 
‘a.out file’. The kernel reads these formats and launches the com- 
piled application appropriately. 

A handy Linux command is file which lets you see what format a 
given file has. Switch to the appropriate directory using cd and then 
type file followed by the name of the file of interest. For example, in 
the Linux directory there is a file called ‘vmlinux’. Typing 


file vmlinux 
produces the answer 


vmlinux: ELF 32-bit LSB executable, ARM, version 1 
(SYSV), statically linked, not stripped 


The file is an executable file for ARM processors that is statically 
linked. 


Power management options 

It is not just the processor that offers power management features: 
many peripherals and other devices have the ability to go into a 
sleep mode. The operating system can take a copy of important 
data and send the peripheral to sleep. When the time comes to 
wake the peripheral up again, the data are copied back from mem- 
ory and its state is restored. The exact behaviour of the kernel in 
these situations can be configured here. 


Networking support 

Finally we come to one of the most interesting points for develop- 
ers. Under ‘networking support’ we can enable, disable and config- 
ure all the software stacks (protocol libraries) for the various com- 
munication interfaces, including Ethernet, TCP/IP, CAN, infra-red, 
amateur radio, Bluetooth and wireless. 


Device Drivers 

We are also especially interested in device drivers. This menu item 
includes everything you might wish for, from the simplest I/O port 
to the most up-to-the-minute high speed server bus. The kernel 
source code (see download at [4]) includes drivers for a wide range 
of USB, I2C and SPI devices which we now have at our disposal. 


File systems 

File systems are important to us for two reasons. First, the operat- 
ing system itself must reside in a file system (on the SD card), so 
that the kernel can read the files it needs from it. And second, the 
operating system has to use a file system to allow application files 
and directories to be stored on a hard disk. 


Kernel hacking 
This menu item is chiefly aimed at kernel developers. 
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Security options 
Linux includes a range of different security features. The most famil- 
iar of these is the system of user and group permissions and the 
existence of a ‘root’ user. Applications can be further protected 
using techniques such as trusted platform modules and internal 
security models. 


Cryptographic API 
This menu item covers cryptographic functions in the kernel. 


Library routines 
This menu item includes functions for calculating checksums along- 
side many other things. 


If you want to save your new kernel configuration, use the last menu 
item ‘Save an alternate configuration file’. After entering a name for 
the new kernel configuration it will be stored locally in the kernel 
source tree. 


We described in the previous instalment in this series [4] how to 
go about compiling the kernel (make zImage) and copying it to an 
SD card. If new modules are to be included in the kernel, they have 
to be separately compiled and installed. Compile the modules by 


typing: 
make modules 


and to copy them to the SD card, either give the path to the des- 
tination SD card directly in the following command, or install the 
modules into ‘/tmp’ and then copy the new directory that is created 
there to the SD card, either as user ‘root’ or using the ‘sudo’ com- 
mand. (It is not that root privileges are required for the copy opera- 
tion itself, but rather that we must ensure that the files are copied 
to the file system on the SD card in such a way that the kernel can 
subsequently use them as the root user.) 


make INSTALL MOD PATH=/tmp modules install 


Now we switch the the ‘/tmp’ directory and copy the directory lib 
to the SD card: 


cd /tmp 
sudo cp -R lib / 
media/86b3be7 -00f3-45e0 -832e-1f48c2c3065e 


with the appropriate change to the long hex string. 


Interfaces 

Linux has its roots in the PC world. There we are faced with inter- 
faces such as IDE, SATA, PCI, AGP and the like. In the embedded 
world the focus is more on the traditional microcontroller interfaces 
and, of course, USB. 
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Table 1. Device files typically found in the /dev directory 
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| Device type File in /dev Character or block device 


IDE hard disk | [dev]hda, Įdevjhdb, .. 








| SCSI hard disk are |dev/sdb, .. 


| Block 


| Block 


C 


ap 





To summarise, our board has the following interfaces: 

e USB (as host and device) 

e UART (in its current form as the system console, but can also be 
used as an interface to external devices) 

e [2C (as master) 

e SPI (as master) 


Also, the processor has other hardware functions such as: 


“ GPIO 
e A/D converter 
e PWM output 


As we proceed we will look more closely at these interfaces. 


Device files 

In order to allow applications to talk to devices, we need an inter- 
face to the device driver. The way that drivers are accessed varies 
greatly from one operating system to another. Linux is based on 
a UNIX file system, and under UNIX things are particularly simple: 
each device is treated as a file. The idea is that no special tools are 
required to drive a device; instead, we can just use small, simple 
programs (from the console), operating on devices exactly as if they 
were files. We showed an example of how this works in the case of 
GPIO pins in the second instalment of this series [5], where we dem- 
onstrated how to flash an LED. 

There are two important commands with which surprisingly much 
can be achieved: cat and echo. The command cat displays the con- 
tents of a file; echo, conversely, lets us write any desired text to a 
file. To put it more precisely, the output of echo can be redirected 
to any desired file. 

So, for example, if we want to write some data directly to a hard disk 
(that is, not via a file system) or send data to a serial port, we can use 
echo in commands of the form 


echo “Data for the hard disk” > /dev/sda 
or 


echo “Hello there, world” > /dev/ttyS0O 
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But be careful: if you wish to experiment with writing data directly 
to a hard disk or memory card, make sure you use one without any 
important information stored on it! 

Some device files correspond to block devices and some to char- 
acter devices. A hard disk, for example, is always treated as a block 
device, whereas an RS-232 interface is treated as a character device 
like a normal terminal, receiving and processing characters one at a 
time. Table 1 gives a list of example device files that might be found 
in a typical UNIX or Linux system. 

Readers may be wondering exactly what mechanism is hiding 
behind the commands echo and cat. How exactly does a driver send 
or receive data? Now, since everything is a file, we can access the 
device by simply reading from or writing to it as we would a file. This 
means that each driver simply has to provide three functions: Read, 
Write and Ioctl (which allows the device’s settings to be changed). 
Read and Write are the standard functions for reading and writing 
files, the process in the case of a device being exactly analogous to 
that for a normal file. The first step is to open the device or file and 
obtain a ‘handle’ (a number which identifies the opened device or 
file). The handle is then passed to subsequent Read or Write opera- 
tions on the device or file. 


Kernel space and user space 

Classical operating systems (in which category we include Linux) are 
generally constructed with a clear separation between the mem- 
ory area that is used by the kernel and the memory area available 
for applications. An application is not permitted to access the ker- 
nel’s memory. This is another important fact for developers work- 
ing close to the system level to bear in mind. In Linux, the memory 
areas are called ‘kernel space’ and ‘user space’. Usually in the case 
of a device driver, all the software will be in kernel space. So how 
does a user application program get its hands on the data received 
over an interface? 

The answer lies in the kernel functions such as copy to user [6], 
which copies a block of data from kernel space into user space. So, 
when an application reads a device file the driver must use this func- 
tion to make the information available to the application. 


Integrating a device driver 


We now know the basic principles of operation of a kernel device driver. 
The question remains, however, of how the kernel knows to associate 
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root@gnublin:~# cat /proc/devices 
Character devices: 
mem 
/dev/vc/@ 
tty 
ttys 
/dev/tty 
/dev/ console 
fdev /ptmx 
VES 
mise 
input 
sy 
126 
ptm 
5 pts 
Spl 
TE 9) 
usb device 
usbmon 
lpc313x_pwm 
Lpe313x_ade 


se) LA a a l jah 


Block devices: 
1 ramdisk 
259 blkext 

loop 
sd 
$d 
sd 
sd 
sd 
sd 
sd 
sd 
sd 
sd 
sd 
sd 
sd 
sd 

4 sd 
sd 


mime 





Figure 2. List of available drivers. 


a file such as /dev/ttyS0 with the correct driver for the serial port. 
To this end so-called ‘major’ and ‘minor’ device numbers are used. 
These are unique identifying numbers that are defined in the kernel 
documentation. The numbers are also present inside the drivers for 
each type of device. 

The following command can be used to display which drivers with 


in:/ cd /dey 
in:/dev# ls -l 


root root console 

root root initetl 

root root 27 66:62 log 

root root Lpe313x_ade 
Crw-r--r-- 1 root root Lpc313x_pwm 
Lirwxrwxrwx 1 root root 3 mtab -> /proc/mounts 
crw-r--r-- 1 root root 3 null 
Crw-F--fF-- root root pcagsss 
CW- tw m= root root 2 Jal ptmx 

root root ) pts 

root root random 

root root sda 

root root 8 Ih sdal 

root root | tty 

root root ; i ttyo 

root root ttyso 

root root urandom 


Figure 3. These files represent our devices. 
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which major numbers are currently available. 
cat /proc/devices 


The result is a list of device drivers, sorted into character devices and 
block devices (Figure 2). 

Now we can look in the ‘/dev’ directory using ls -1 to display its 
contents (Figure 3). There will be a large number of files in the direc 
tory representing our various devices. Let us look at the information 
provided alongside each device. At the beginning is the letter ‘c’ 
or ‘b’ which indicates whether this is a character device or a block 
device. Then there are the permissions as usual: we will look at these 
in more detail in a later article in this series. Then the user who is 
the ‘owner’ of the file. Shortly after that there are two numbers 
separated by a comma, and these are the major and minor device 
numbers. In this example the major numbers are 1, 4, 5, 8, 89, 253 
and 254; the minor numbers are 0, 1, 2, 3, 9, 12, 24 and 64. 

If we access one of these device files from user space, the operating 
system will be able to determine from these numbers and from the 
entries in ‘/proc/devices’ exactly which driver is needed. 


It is easy to create device files using the tool ‘mknod’ [7]. We will see 
an example of this below. 


Integrating a USB-to-serial converter 

It’s now time to turn theory into practice. Let us drive a simple USB- 
to-serial converter from our Linux board (from the USB end!): see 
Figure 4. The basic steps in the process are as follows. 


e Enable the driver in the kernel. 

e Compile the kernel. 

e Copy the new kernel to the SD card. 

e Check the driver is available in the new kernel. 
e Create a device file. 


=F Wahai. UC Yg 
B = H | 
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Figure 4. A CP2102-based USB-to-serial converter 
connected to the Elektor Linux board. 
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e Test the device. 
Enable the driver in the kernel 
First switch to the Linux source tree: 


cd ElektorLinuxBoardDownload 20120509/ 
cd linux-2.6.33-lpc313x/ 

./set.h 
make menuconfig 


In the first step (Figure 5) select the menu item ‘Device drivers’. 
Then select ‘USB support’ (Figure 6). With the default configuration 
there will be an ‘M’ here instead of the ‘*’ shown in the screenshot. 
Use the space bar to cycle through the three options ‘M’ (compile as 
module), ‘*’ (compile into kernel), or neither. We select ‘*’ to avoid 
the complexity of having to hunt down the module later. The next 
menu item is ‘USB serial converter support’ and here also we must 
turn the ‘M’ into a ‘*’ (see Figure 7 and Figure 8). Pressing the Enter 
key brings up a submenu to select the right driver (Figure 9). Most 
readers will probably want to use the FTDI devices or the Silicon 
Labs CP210x controllers, and so we set both of these drivers to ‘*’. 
To apply these changes, go repeatedly to ‘Exit’ and then, on the last 
page, confirm that you want to save a new configuration file. 


Compiling the kernel 
We can now set off the kernel compilation process. 


make zImage 
Typical resulting output is shown in Figure 10. 


Copy the kernel to the SD card 

Put the SD card from the board into an SD card reader and then 
connect the reader to the PC. Now copy the kernel to the SD card 
as follows 


sudo cp arch/arm/boot/zImage / 
media/386b3be7 - 00f3 -45e0 -832e-1f48c2c3065e/ 


with, as before, the appropriate change to the long hex string. 
When the copy operation is complete unmount the file system 
manually in order to ensure that all the blocks are safely written to 
the SD card [4]: 


umount /media/386b3be7 -00f3-45e0-832e-1f48c2c3065e 


Check that the driver is available 

Now we can boot up the Elektor Linux board as usual. It is impor- 
tant to check that JP1 is fitted, so that we force the USB interface to 
start up in host mode. We must also make sure that the device is 
provided with power over the USB connector from the Linux board. 
This is done by fitting J3 in position 3-2. 
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Figure 5. The 'Device drivers' menu item. 
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Figure 6. The 'USB support’ menu item. 
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Figure 8. Selecting 'USB serial converter support' to be built 
as a dynamically-loadable module. 
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Figure 9. Here we select the USB-to-serial adapter(s) 
that will be supported. 


We can see the first differences during the boot process itself. The 
two new drivers make their appearance as follows. 


cp210x: v0.09:Silicon Labs CP210x RS232 serial 
adaptor driver 


USB Serial support registered for FIDI USB Serial 
Device 


Creating a device file 
The command cat /proc/devices reveals a new entry ‘188 tty- 








USB’. We create a device file with this major number as follows. 
mknod /dev/ttyUSBO c 188 0 

Testing the device 

If we now plug the USB-to-serial adaptor into the board we get the 


following output. 


usb 1-1: New USB device found, 
idProduct=ea60 


idVendor=10c4, 


usb 1-1: New USB device strings: 
SerialNumber=3 


Mfr=1, Product=2, 


usb 1-1: Product: 
Controller 


CP2102 USB to UART Bridge 


usb 1-1: Manufacturer: Silicon Labs 


usb 1-1: SerialNumber: 0001 


cp210x 1-1:1.0: cp210x converter detected 

usb 1-1: reset full speed USB device using lpc-ehci 
and address 2 

usb 1-1: cp210x converter now attached to ttyUSBO 

The last line shows that the device file has been correctly created, 
and that the kernel has associated the newly-recognised device with 
the right device file. 

Our Linux operating system includes a small terminal emulator pro- 
gram called ‘microcom’. By adding a jumper to bridge the RXD and 
TXD lines of the serial port on the USB-to-serial adaptor we can use 
this to test the driver. Start up the terminal program using the fol- 
lowing parameters. 


microcom -s 9600 /dev/ttyUSBO 


If you now type characters at the keyboard they will be sent to the 
adaptor and then returned to the board. If the driver is working 
properly these characters should then be echoed to the screen. 
Break the connection between RXD and TXD on the USB-to-serial 
adaptor and the characters should no longer be echoed, demon- 
strating that the device driver is working. Press control-X to close 


Internet Links 


[1] sauter@embedded-projects.net 
[2] http://en.wikipedia.org/wiki/ 
Operating_Systems:_Design_and_Implementation 


[3] http://en.wikipedia.org/wiki/Process_control_block 
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[4] www.elektor.com/120180 
[5] www.elektor.com/120146 
[6] www.gnugeneration.com/mirrors/kernel-api/r4299.html 


[7] http://wiki.linuxquestions.org/wiki/Mknod 
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cc arch/arm/boot/compressed/misc.o 
In file included from arch/arm/boot/compressed/../../../../lib/decompress inflate.c:16:6, 
from arch/arm/boot/compressed/mise.¢:248: 
arch/arm/boot/compressed/../../../../lib/zlib inflate/inflate.c: In function "zlib fixedtables': 
arch/arm/boot/compressed/../../../../lib/zlib inflate/inflate.c:160:1: warning: the frame size of 2176 bytes is larger than 1024 bytes 


SHIPPED arch/arm/boot/compressed/libltuncs.$s 
AS arch/arm/boot/compressed/lLiblfuncs.o 
LD arch/arm/boot/compressed/ vmlinux 
OBJCOPY arch/arm/boot/zImage 

Kernel: arch/arm/boot/zImage is ready 





Figure 10. Output when compiling the (newly extended) kernel. 


microcom. (120181) 
In the same way we can modify the kernel to use USB adaptors for 
LAN and WLAN, USB sound cards and many other USB devices. 


In the next instalment in this series we will look at more devices and 
interfaces and test them out with a few simple experiments. 


Elektor RF & Microwave O SiliconRay 
Toolbox Online Electronics Store 


E> for Android 


The RF & Microwave Toolbox contains 

34 calculation and conversion tools for 

RF, microwave and electronics in general. 
Whether you are an RF professional, 
radio-amateur, astronomer or hobbyist, 
this app puts some of the most impor- 
tant tools right at your fingertips. Literally! 


è Boards ® Kits è Modules ® Components ® Tools ® Instruments 
FOR 


e Companies #Professionals ® Students #DlYers ® Amateurs 


Mini multimeter DT-830B 
Free, Portable, Multifunction 





SEN1060 GPS Module With Antenna 


Small, Low Cost,Easy To Develope 
Highlights: 


e Amplifier cascade (NF, Gain, P1db, 
OIP2, OIP3) 

e Field intensity and power density 
converter (W/m2, V/m, A/m, 
Tesla, Gauss,dBm, W) 

e PCB Trace calculator 
(impedance/dimensions) 

e PI and T attenuator 

e Antenna temperature (Kelvin) 






USB AMR JTAG Simulation J-Link v8 


“Must have” tool for ARM developers 


Download 
your app now! 





6P3P 7.5Wx2 Tube Amp Kit 
e EMC (EIRP, ERP, dBuV/m) 2. | ul 4 CNC enclosure, hifi sound quality, easy to build 


e Filter Design (Butterworth, Chebyshev, prototype) 
e And much more 


Further information at 


simplify your electronics projects by visiting 


http://www.siliconray.com 


www.elektor.com{rf-app 
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Thou Shalt Communicate! 


Wi-Fi/Bluetooth/USB shield 
for Platino and Arduino 


By Clemens Valens 
(Elektor UK/INT Editorial) 


Today all & 
sundry, devices 
included, have to 
be “connected”, 24/7, all 
year round. You may have 
a Facebook account, but 
what about your oscilloscope? 
Does your multimeter tweet 
enough? Is your soldering iron 
linked in? You may be a non- 
communicative nerd but your 
bench power supply may be 
craving for social interaction. 
With the add-on board described 
in this article you can hook up 
anything to everything, with or 


without wires. 
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Okay, | can’t deny it; | 
have a reputation for exagger- 

ating. Connecting anything to, errm, 
everything is probably a bit over the top. On 
the other hand, the board I’m about to pre- 
sent in this article is quite versatile. It can 
be equipped with a Wi-Fi module allowing 
you to connect an electronic device to the 
Internet; or with a serial Bluetooth module 
it offers wireless connectivity to other serial 
Bluetooth capable devices, and a serial-to- 
USB bridge enables old-skool wired serial 
connectivity. 


The board can be used as an add-on board 
for microcontroller systems with Arduino- 
style extension connectors (Figure 1), like 
Elektor’s own Platino [1] (Figure 2), but it 












also be used 
stand-alone as a wire- 
less connectivity module for 
a PC. Note that you can’t have both 
Wi-Fi and Bluetooth modules mounted on 
the same board. 


About the Wi-Fi module 

Wi-Fi modules have been inexpensive, plen- 
tiful and easy to find these past few years. 
The problem with many of them however 
is their manufacturer who refuses to tell 
you how to use the module unless you 
agree to transfer a substantial amount of 
money to the manufacturer’s bank account 
in exchange for a few thousand modules 
or a customised software library for your 
host hardware. Luckily the Korean embed- 
ded Internet liberators from WlZnet have 
decided to be less secretive about their 
products, and sell Wi-Fi modules you can 
actually use. | managed to get my hands 
on two of their WizFi220 modules, and this 
article is the result. 


10-2012 elektor 


The WizFi2x0 modules (there is also a 
WizFi210 module) operates with standard 
802.11 b/g/n access points at speeds up 
to 11 Mbit/s (802.11b), and they support 
WEP, WPA, WPA2-PSK and Enterprise secu- 
rity standards (802.11i). The modules have 
some really cool possibilities. One of them 
is the Wi-Fi serial port that’s remarkably 
easy to use. Another nice feature is its lim- 
ited access point (AP) capability that allows 
direct connection to smartphones and tab- 
lets like Android-based devices and Apple 
gadgets. 


The WizFi220 module measures 
32 x 23.5 x 3 mm, has an on-board chip 
antenna and a Hirose U.FL connector for an 
external antenna. The module’s compatible 
little brother, the WizFi210, consumes less 
power, but cannot provide as much out- 
put power and hence has “less range”. 49 
connection pads provide enough soldering 
points to fix the module on a PCB in such a 
way that it will not easily come off. Most of 
these pads are probably not useful for unas- 
suming users like us, being pitched at high- 
volume customers. For the others a simple 
two-wire serial connection is available to 
transmit and receive data and to configure 
the module. 


As is often the case with such wireless mod- 
ules, the WizFi2x0 can be controlled over a 
serial link using AT modem commands (or 
Hayes commands). Such commands con- 
sist of human-readable strings a few charac 
ters long and starting with ‘AT’. The module 
powers on in Command mode so you can 
configure it. Once the setup is complete the 
module can be switched into Data mode 
with the O(nline) command (“ATO”). To 
get it out of Data mode back to Command 
mode three consecutive ‘+’ characters have 
to be send (“+++”). 


Design considerations 

Some of the configuration commands, like 
setting the baud rate of its serial port, are 
more or less one-time only, and the mod- 
ule remembers these settings. Since the 
AT commands are human-readable it may 
therefore be practical for the initial setup, 
but also for experimenting, to be able to 
communicate with the module using a PC 
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Figure 1. Fully built up Wi-Fi shield on top of an Arduino Uno. 
Note the absence of R8 and R10. 


and a serial terminal program. That’s why 
| decided to throw in a serial-to-USB con- 
verter. Since many Elektor readers may 
already have a so-called FTDI serial USB 
cable [2], | wanted to be able to use it 
with this module. On the other hand, hav- 
ing such a converter directly on the board 
would also be useful, especially if the host 


system does not have a USB serial port, 
like Platino. In the September 2011 edition 
we presented BOB [3], a very convenient 
USB/serial bridge module, and | thought 
it was a good idea to add it to my design 
too. Now if | could add some clever wiring 
it should be possible to connect the USB 
converter to either the Wi-Fi module, the 





Figure 2. Fully built-up Wi-Fi shield on top of Platino, 
also equipped with a 20x4 alphanumerical LCD. 
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Figure 3. Complete circuit diagram of the Wi-Fi/Bluetooth/USB shield. 
Refer to the text to find out which parts you need for each configuration. 


host system or even disconnect it. Flexibil- 
ity started creeping into the design. 

The Wi-Fi module has to be powered from a 
3.3 V rail and it is not 5 V tolerant. The main 
objective is to connect the Wi-Fi module’s 
serial port to a microcontroller. Such a sys- 
tem may run from 3.3 V, but if it is Arduino 
or Platino, then the microcontroller runs 
from 5 V. Level converters on the serial port 
would therefore be necessary. The FTDI 
serial USB cable comes in two flavours, 5 V 
and 3.3 V, and with level converters both 
types would be usable. The BOB was not an 
issue because it can handle both levels. 
Although the host system may have a 3.3 V 
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rail, like Arduino, | thought it wise to add 
a voltage regulator to the system because 
the WizFi220 can consume up to 250 mA in 
active mode. As an example, the LP2985-33 
voltage regulator on an Arduino Uno board 
is specified for 150 mA, which is clearly not 
enough. Platino does not have a 3.3 V rail 
so this shield could provide it too. A jumper 
should allow connection of the 3.3 V as pro- 
duced by the shield to the host system. 

In this section you can replace all instances 
of “Wi-Fi” by “Bluetooth” without having to 
change anything else and still have a coher- 
ent text. Indeed, many Bluetooth modules 
are very similar to the WizFi module: they 


can be controlled with AT commands over 
a serial link; they run from 3.3 V; they have 
similar dimensions and similar require- 
ments. It is therefore not very difficult to 
add Bluetooth capabilities to the system, 
all you have to do is wire a usable Bluetooth 
module in parallel with the Wi-Fi module 
and that is what | did. | chose the Rayson 
BTM220 module because | am at ease with 
it [4] and it is very cheap. We have used it 
several times in Elektor too. [5][6] 


This completes the reasoning that deter- 


mined my design. Let’s now have a closer 
look at the circuit diagram (Figure 3). If you 
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COMPONENT LIST 


Resistors 


R1-R11 = 1kQ 5% 0.25W 
R12,R13 = 47kQ 5% 0.25W 


Capacitors 


C2, C3 = 100nF 50V, 5mm pitch 
C5 = 220nF 50V, 5mm pitch 
C1, C4= 10uF 35V, 2.5mm pitch 


Semiconductors 

D1,D2,D3 = LED, green, 3mm diam. 

T1-1T4 = BC547C, TO-92 case 

IC1 = MCP1825S-3302E/AB, 3.3 V volt- 
age regulator, TO-220 case 


Miscellaneous 

JP1 = 6-pin pinheader, 0.1” pitch, 
straight 

JP3,JP4 = 3-pin pinheader, 0.1” pitch, straight, 
w. 2 jumpers 


have grasped my prose up to here, then the 
schematic will have only a few surprises. 


Putting it all together 

On the left side of figure 3 we have the Wi-Fi 
module; on the right side we see the Blue- 
tooth module. As you can see they share 
the serial RX and TX lines, meaning that 
you should not mount both. It is either 
Wi-Fi or Bluetooth, never both. The mod- 
ules also share two LEDs (D1 and D2); D3 
is only used by the Wi-Fi module. A surprise 
here may be R8 and R10. Maybe | could have 
drawn a better schematic, but | didn’t, so 
| have to explain this in writing. It is actu- 
ally very simple. The Wi-Fi module sinks the 
current for the LEDs whereas the Bluetooth 
sources the current. As a result the LEDs 
have to be mounted the other way around 
as drawn if you use the Bluetooth module. 
In that case you should mount R8 and R10 
and not mount R7 and R9 (mounting R11 
and D3 is useless unless you connect the 
LED to a free I/O pin on one of the connec 
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JP2 = 4-pin pinheader, 0.1” pitch, straight 
K1,K3, K4 = 8-pin stackable header, 0.1” pitch, 
vertical 


tors). For the Wi-Fi module the position of 
the LEDs is drawn correctly and you should 
not mount R8 and R10 (although nothing 
breaks or blows if you do), only R7 and R9 
are needed now. 


The WizFi module has some pins with spe- 
cial functions that you may want to use. 
Since | didn’t use them | wired them to a 
separate connector JP4. To enable you all 
to stack many shields on top of each other 
| decided not to wire these signals to the 
Arduino extension connectors K1 to K4. If 
you need them you can wire them your- 
self. Pin 25 (GPIO 21) allows you to restore 
the module’s factory defaults. Pulsing it 
Low twice will restore the module to Lim- 
ited Access Point mode, three pulses will 
restore it to Ad-hoc mode. Pin 46 (GPIO 29) 
provides a hardware way of switching 
between Command (High) and Data 
mode (Low). Pin 37 (GPIO 27) is needed 
when you want to upgrade the firmware 
of the module (probably never). To do so 


K2 = 6-pin stackable header, 0.1” pitch, 
vertical 

K5 = 6-pin (2x3) stackable header, 0.1” 
pitch, vertical 

S1 = pushbutton, SPNO, through-hole, 
6x6mm 

Mod3 = BOB-FT232R USB-to-Serial 
Bridge, Elektor Shop # 110553-91, or 
USB-to-Serial cable, Elektor Shop # 
080213-71 (5 V) or #080213-71 (3.3 V) 
Mod2 = Rayson BTM22x Bluetooth 
module 

Mod1 = WlZnet WizFi2x0 Wi-Fi module 
PCB # 120306-1 [1] 


you have to pull it High. Finally, a low level 
on pin 7 (Alarm1) will wake up the module 
from deep sleep mode. 

The level converters (R1-3, T1-2 and R4-6, 
T3-4) are straightforward and have been 
used before in Elektor. Transistors T1 and T4 
do the level conversion, but invert the sig- 
nal at the same time. T2 and T3 correct this. 
The resistor values are not critical. | chose to 
use as many 1 kQ resistors as possible. 

The RX and TX lines connect to JP1 and JP2. 
These 3-pin jumpers may be a bit difficult 
to understand at first sight, but when you 
follow the lines you should be able to fig- 
ure them out. With a jumper on JP1’s pins 
1 and 2 the USB serial converter TX pin 
is connected to the Wi-Fi (or Bluetooth) 
module’s RX input. A jumper on JP2’s pins 
2 and 3 connects the USB serial converter 
RX pin to the Wi-Fi (or Bluetooth) module’s 
TX output. This is the Configure-Module- 
With-PC mode. In these positions the USB 
serial converter cannot talk to the host MCU 
system and it may be better to disconnect 





Elektor Projects & Products 


e Platino, a versatile board for AVR microcontroller circuits (October 2011); PCB # 100892-1 from Elektor Shop 
e BOB-FT232R USB-to-Serial Bridge (September 2011); module, Elektor Shop # 110553-91 
e USB-to-TTL Serial Cable (June 2008); cable, Elektor Shop # 080213-71 (5 V) or # 080213-71 (3.3 V) 
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Listing 1. 


Example of setting up the WizFi2x0 module as a serial server using AT commands. The commands are in boldface, the module’s responses 


are in italic. Comments appear in brackets (). See the WizFi2x0 user manual for more commands. 


AT (wake up) 

[OK] 

AT+NSTAT=? (what is your status?) 
MAC=00:08:dc:18:97:76 
WSTATE=NOT CONNECTED 
BSSID=00:00:00:00:00:00 
IP addr=0.0.0.0 
RxCount=0 TxCount=0 
[OK] 


MODE=NONE 


SSID="" CHANNEL=NONE 
SubNet=0.0.0.0 Gateway=0.0.0.0 DNS1=0.0.0.0 DNS2=0.0.0.0 


SECURITY=NONE RSSI=0 


AT+WPAPSK=germaine,”Philippe Noirette” (set SSID & pass phrase) 
Computing PSK from SSID and PassPhrase... 


AT+NAUTO=1,1,,8011 (setup for auto connect: server, TCP, port 8011) 


[OK] 
AT+NDHCP=1 (request IP number from DHCP server) 
[OK] 
AT+WAUTO=0,germaine (automatically connect to germaine) 
[OK] 
[OK] 
ATA (start auto connect) 
IP SubNet 


Gateway 


192.108 2./: 255.255.255.0: 192.1085. 2.1 


[0K] 


(now you can connect (telnet) to the module over Wi-Fi) 


the board from the host system. The board 
will be powered from the USB port. 

If you put a jumper on JP1’s pins 2 and 3 
and on JP2’s pins 1 and 2 the USB serial con- 
verter can be used to talk to the host sys- 
tem. In this case you should not mount the 
wireless module (or the level converters) as 
this kind of communication may disturb it. 
This is the USB-Shield mode. 

Not installing any jumpers will put the 
board in Wireless mode and the USB serial 
converter has no use. However, you could 
leave it on and wire it to other pins on the 
extension connectors. This is for instance 
useful in an Arduino-with-software-UART 
configuration or in a host system with more 
than one UART. 


Finally some remarks on details. The Reset 
button is mainly intended for Platino which 
doesn’t have one. It is also useful when the 
Arduino reset button becomes inaccessible 
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because of the shield mounted on top of 
it. This depends on the Arduino board and 
its revision. 

K5 is not connected. | only put it on the 
board to provide access to its signals if the 
host is Arduino. 


Turning practical 

To turn a circuit diagram into a real shield 
or extension board a printed circuit board 
(PCB) is needed. | designed one and you can 
download the Eagle CAD files from the web 
page that accompanies this article [7]. The 
PCB is the size of an Arduino Uno except that 
it is a rectangle without the funny-shaped 
short side of an Arduino Uno. All the compo- 
nents are through-hole types; only the Wi-Fi 
and Bluetooth modules have surface mount 
footprints. JP5 and the Bluetooth module are 
located on the solder side of the board; the 
other components should go on the compo- 
nent side. Note that if you use non-stackable 


connectors for K1 to K4 you should mount 
them on the solder side if you want to stick 
the board on an Arduino or Platino. 

JP1 and JP2 are positioned in such a way that 
the jumpers should always be in the same 
position, i.e. both to the left, both to the 
right or both absent. Actually, you could 
leave a jumper on JP2 in case you wanted to 
listen in on the MCU wireless module com- 
munications. This can be useful for debug- 
ging purposes. 

JP3 has a few contacts in common with the 
BOB serial-to-USB bridge, the idea being 
that you use either a BOB or an FTDI cable, 
not both. 

For full 3.3 V systems the level converters 
and voltage regulator can be left off. In this 
case you have to place two bypasses (wire 
bridges) from R3-JP1 to R2-T2 and from 
R6-MOD1 to R5-T3. Resistors R3 & R2 and 
R5 & R6 are positioned in such a way that 
the wire bridges are very easy to install and 
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WI-FI/BLUETOOTH/USB SHIELD FOR PLATINO AND ARDUINO 
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Figure 4. The three main configurations next to each other. The Bluetooth module is not visible (middle board) because it is mounted on 
the other side of the PCB. Note that this is an early revision of the PCB that has the same shape as an Arduino Uno board. The final PCB is 


span only minimum distance. You will also 
have to short JP5 on the solder side of the 
board. 

As mentioned before, the orientation of the 
LEDs depends on the wireless module. The 
component print on the PCB corresponds 
to the Wi-Fi module. If you mount a Blue- 
tooth module you should mount the LEDs 
D1 and D2 ‘the wrong way around’. Also, 
only mount R7 or R8 and R9 or R10. 

The 3.3 V voltage regulator can be installed 
lying on his back or standing up. 


Three main configurations are possible (Fig- 
ure 4), but you may have a need for other 
variants: 


e Wi-Fi shield — no need for the BOB if 
you own an FTDI cable, although you 
can always install one. JP3 is available 
for connecting the FTDI cable. Mount all 
LEDs as indicated on the PCB and do not 
mount R8 nor R10. Level converters will 
be needed and the 3.3 V voltage regu- 
lator probably too, depending on your 
host system. 


Bluetooth shield — similar as the Wi-Fi 
shield except for the LEDs. D3 has no 
function and you should not mount R7 
and R9 but mount R8 and R10 instead. 
As an antenna you can use a piece of 
(insulated) wire of 31 mm long. 


e Serial-to-USB bridge shield — just the 
BOB without level converters. Do not 
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rectangular. 


forget to put a drop of solder on JP1 of 
the BOB to configure it for 5 V or 3.3 V 
operation. Add 3.3 V voltage regula- 

tor and reset push button to taste. The 
LEDs can be useful too, but you will have 
to wire them to a connector pin. You 
should short pins 2 and 3 of JP1 and pins 
1 and 2 of JP2 with a jumper or a wire 
bridge. 


Testing 

In case of the Wi-Fi or Bluetooth configura- 
tions connect the board to a USB port on the 
PC using an FTDI serial converter cable or the 
BOB serial-to-USB bridge. Figure out which 
COM port was created by the operating sys- 
tem (OS) of your PC (make sure you have the 
appropriate drivers for your OS installed. If 
you haven’t you can get them, including the 
necessary documentation, at www.ftdi- 
chip.com) and start a serial terminal pro- 
gram. The WizFi220 module has a default 
baud rate of 115 200 bits/s, for the BTM220 
module this value is 19 200. Both modules 
use 8 bits, no parity and no hardware flow 
control. In the terminal type ‘AT’ followed 
by the Enter key. If you set up everything the 
right way the module should respond with 
‘[OK]’ or ‘OK’. If this test succeeds you’re 
in business. Refer to Listing 1 for a working 
Wi-Fi example (don’t forget to adapt the 
SSID and pass phrase to your network). 

For a BOB serial-to-USB bridge configura- 
tion the steps are more or less the same 
except that there is no point in punching in 
AT commands in the terminal unless your 


host system responds to these. It is up to 
you to provide a host that can communicate 
over a Serial link. 


Thanks go out to Joachim Wulbeck of WiZnet 
Europe GmbH (www.wiznet.eu) for providing 
the WizFi220 modules and the Wi-Fi antennas. 

(120306-1) 


Internet Links and References 


[1] Platino: www.elektor.com/100892 


[2] USB-to-TTL serial cable: 
www.elektor.com/080213 

[3] BOB serial-to-USB bridge: 
www.elektor.com/110553 

[4] Experiments with Rayson Bluetooth 
modules: 
http://elektorembedded.blogspot. 
com/2010/08/rayson-btm222-btm1 12- 
bluetooth-modules.html 


[5] Bluetooth with the ATM18: 
www.elektor.com/080948 


[6] Bluetooth for OBD-2: 
www.elektor.com/090918 


[7] Wi-Fi shield: www.elektor.com/120306 

[8] Wi-Fi shield on Elektor Projects: 
http://www.elektor-projects.com/pro- 
ject/wi-fi-bluetooth-usb-shield-for-ardui- 
no-platino.12252.html 
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AVR Software Defined Radio (6) 


By Martin Ossmann (Germany) 


This series has demonstrated that the ever- 
popular AVR controllers are also useful for 
signal processing. In this final instalment we 
take a closer look at a few more decoding 
methods. As usual we like to back up the 
theory with some practice: This instalment 
shows how to extract time-of-day information 
from BBC AM broadcasts. 


In the last instalment of this series [5] we demonstrated the decod- 
ing of time-signal transmissions. Using the described digital IIR and 
matched CIC filter it is possible to receive and decode time signals 
sent by the German DCF77, the UK MSF and French TDF162 stations. 
In this instalment we go on to decode the digital information trans- 
mitted by the BBC on long wave at 198 KHz (Droitwich) and also the 
recently discontinued medium wave 648 KHz service. To this aim we 
look at alternative decoding strategies and demonstrate how they 
can be implemented. 


Bit-clock synchronisation 

In the world of communications technology there are many meth- 
ods by which synchronous data can be sent through the ether. Here 
a digital data stream runs continuously through the communication 
system at a defined clock rate. At the receiver the signal often first 
undergoes demodulation. The resultant signal is then a sequence 


31.25Hz 


Figure 1. Frequency spectrum of the 31.25 Hz data signal. 
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of data bits which contain the transmitted information. 

For this experiment to achieve bit-clock synchronisation with the 
receive data it will be necessary to use a simple radio front-end (or 
the receiver board available from the Elektor shop), the receiver 
software ‘EXP-RX-FM-125kHz-RDSlike-BitSyncV01.c’, a signal gen- 
erator with a 125 kHz series resonant circuit and the transmitter 
software ‘EXP-TX-FM-125kHz-RDSlike-V01.c’. This last program 
generates frequency modulated digital data at 125 kHz with a data 
rate of 31.25 bit/s. The data stream and bit clock are output from 
the D/A converter outputs. 

At the receiver site the signal is sampled at a frequency of 


31.25 Hz x 16 = 500 Hz 


to recover the clock. Each bit is therefore sampled 16 times. You 
could try to reconstruct the 31.25 KHz bit clock from the received 


31.25 Hz 


Figure 2. The spectrum of the rectified data signal. 
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data signal by using a PLL (phase locked loop). Unfortunately it is 
not quite so simple. The reason becomes clear when you look at the 
received signal spectrum given in Figure 1. There is in fact no signal 
component at 31.25 Hz for a PLL to lock onto. 

Once the data signal has been rectified however, its spectrum (Fig- 
ure 2) now shows a component at 31.25 Hz. A PLL will now be able 
to lock onto the signal. The principle of the data recovery PLL is out- 
lined in Figure 3. 

This PLL is in fact similar to the design used in an earlier instalment 
of this series to recover the carrier frequency (see Figure 7 in the 
fourth instalment of this series [4]). With reference to the ‘EXP-RX- 
FM-125kHz-RDSlike-BitSyncV01.c’ program the bit-clock frequency 
is controlled in the following manner: The do-Signal-Sample() rou- 
tine in Listing 1 is called at 16 times the bit clock rate. In this routine 
the variable Clk16 is incremented or reset to zero when it reaches 
16. The phase of the saw-tooth signal is regulated so that the centre 
of the ramp (Clk16 = 8) is coincident with the centre of the transmit- 
ted bit. The bit value is evaluated and processed in the routine doBit- 
Sample(). Phase adjustment is performed in the following manner; 
in the normal case Clk16 is incremented to 16 and then reset by the 
digital signal clock. Now depending on the sign of the output from 
the phase comparator this value can be changed to either 15 or 17 
to provide some phase adjustment. 

In order to correctly control the clock PLL it is necessary to output 
the demodulated signal at the output of DAC1. Clk16 with Peak 
at Clk16 = 8 (i.e. at the sampling instant) is output from DAC2. 
Figure 4 shows the reception of BBC Radio 4 at 198 KHz LW (see 
Figure 5). 


Early-Late Synchroniser 

In addition to the conventional PLL a so-called ‘Early-Late’ synchron- 
iser can be used to recover the clock signal. The eye-diagram shown 
in Figure 6 helps explain how this technique works. 

Again it is necessary for the Clk16 signal to synchronise with the 
bit clock so that the data signal is sampled in the centre of the bit. 
In order for this to be achieved the signal is sampled at the early 
time E and the late time L. This can be performed, for example on 
the third (E) and twelfth (L) clock of the Clk16 clock. When both 
of these measured values are the same amplitude then we can be 
confident that E and L are centred about the mid point. When on 
average one set of the values is greater than the other it indicates 
that the eye has shifted from its optimal point and phase of Clk16 
requires some correction. 

The program code corresponding to this process in given in List- 
ing 2. Ten samples of the E (early) and L (late) values are summed to 
produce the value ‘earlyLateDelta’. This value is then used to correct 
the Clk16 period. The code for this synchroniser can be tested with 
the ‘EXP-RX-FM-125kHz-RDSlike-BitSyncV01.c’ program. 


Decoding the phase modulated BBC198 signal 

Now we come to a practical application of bit synchronisation when 
we program the receiver to recover the phase-modulated data sent 
out by the BBC as part of its Radio 4 LW broadcast on 198 kHz. 
Details of the transmitted signal are given in the BBC publication 
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Figure 3. The clock-PLL principle. 


Listing 1: Phase adjustment 


void advanceCLK16() { 
Clk16++ ; 
if ( Clk16 >= ClockPeriod ) { Clk16=0 ; } 
} 


void doSignalSample() { 
int16 t Signal ; 
ATOMIC BLOCK(ATOMIC FORCEON) { 

Signal=FRQcicout ; 

} 
ClockPLL16(Signal) ; 
doBitSample(Signal) ; 
advanceCLK16() ; 





[7]. Data is sent by modulating the 198 KHz carrier phase by +22.5°. 
The data rate achieved is 25 bit/s using Manchester coding (also 
known as bi-phase coding) with filtering. Using this type of modula- 
tion ensures that the average phase deviation always sums to zero 





Figure 4. Eye diagram of the BBC198 signal. 
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Figure 5. The complete receiver for reception of BBC198. 


Signal 
Eyepattern 


| CLK16 


Figure 6. Eye diagram of the early-late synchroniser. 


Listing 2: Early-Late Synchroniser 


void earlyLateSynchronizer(int16 t Signal) { 
if ( Clkl6==3 ) { earlyValue=abs(Signal) ; } 
if ( Clkl6==12 ) { lateValue=abs(Signal) ; } 
if ( Clkl6==8 ) 4 
earlyLateDelta += lateValue-earlyVaLlue; 
ClkCnt++ ; 


ClockPeriod=16 ; 

if (ClkCnt==10) { 
ClockPeriod += earlyLateDelta/16 ; 
earlyLateDelta=0 ; 
ClkCnt=0 ; 
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so (as before the modulation was introduced) the carrier can still be 
used as a highly stable frequency reference. 
The A/D converter uses a clock equal to 


20 MHz / 2,500 = 8 kHz. 
At this sampling rate the 198 kHz carrier is mixed down to 
198 kHz - (25 x 8 kHz) = -2kHz. 


The ‘intermediate frequency’ is therefore -2 kHz and is sampled at 
four samples per period in the same way as in the IQ sampling mixer 
earlier. The negative sign indicates that the mirrored sideband is 
used. After separation into the / and Q components both are first 
passed through second-order CIC filters and downsampled with an 
M, factor = 16. Next in line is another low-pass CIC but this time 
without downsampling. Instantaneous values of amplitude and 
phase values are now produced from these filtered / and Q signals 
processed using the CORDIC process. 

One possibility for signal demodulation is to use a PLL to recover the 
carrier and then decode the NRZ (Non Return to Zero) signal. Here 
it refers to the original data signal which has been used to phase 
modulate a carrier and which will be recovered in the receiver. For 
decoding however the use of a PLL control loop which interprets a 
phase modulation as a frequency modulation is not necessary. The 
conversion is shown in Figure 7. 

The theoretical NRZ-phase response is represented as a signal 
response p(t). To reduce the signal bandwidth phase changes occur 
only slowly. The actual phase response is more like the signal q(t). 
The sampling rate for the demodulated signal is 400 Hz so each bit 
is sampled 16 times. Now according to communication theory fre- 
quency is the rate of change of phase. The frequency response f(t) is 
given by the derivative of q(t) with time. When the phase increases 
linearly with time there is a constant positive frequency. When the 
phase decreases linearly with time there will be a constant nega- 
tive frequency. 

Using additional low pass filtering the signal g(t) is recovered from 
f(t) and can now be readily evaluated. The data stream is sampled 
mid-bit to determine its value. When the value is positive it is inter- 
preted as a ‘1’ and when negative as a ‘0’. Application of the CORDIC 
algorithm produces phase samples to give the instantaneous fre- 
quency. These are again low-pass filtered with a CIC filter to produce 
the signal g(t). This signal in turn supplies the bit-clock recovery. 
This results in the waveform shown in Figure 8 in the second instal- 
ment of this series [2]. 

With more processing the blocks of data are identified and decoded. 
How this functions will be explained later on. For now Listing 3 
shows a data sample received from the BBC 198 kHz signal. 


Block Synchronisation 

Once the data bit stream has been recovered from the receive signal 
the final task is to identify the beginning and end of the data packet. 
This process is known as block synchronisation. 

The majority of radio traffic systems use blocks of data of fixed 
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length. When the receiver is first switched on it is necessary to 
determine where the beginning of each block occurs in the data 
stream. There are several commonly used techniques to identify 
data start; one method is to use a unique sequence of bits to form a 
preamble. This sequence is never allowed to occur in the data field. K 
RFID tags of the type EM4102 use this method. This preamble occu- 
pies space in the data stream and therefore, to some extent reduces 
the available channel data bandwidth. Many communication sys- 
tems use the information contained in the data for error correction 
field as the block boundary marker. 


Error detection 

Many data communication systems use a checksum added to the 
end of each block of data which allows the receiver to detect data 
corruption and also to correct the error. It can be shown that this 
additional information can also be used to perform block synchro- 
nisation. First we will describe how the checksum is calculated using 
the 125 KHz test transmitter together the ‘EXP-TX-FM-125kHz- 
RDSlike-V01.c’ program. The calculation software is given in List- 





Figure 7. Phase modulation as frequency modulation. 


ing 4 and the CRC hardware generator block diagram is shown in Listing 3: BBC 198 kHz signal: receive Data 
Figure 8. 

Ten CRC check bits are calculated using a shift register with XOR +E EB11 0391 

gated feedback taps. The 16 data bits are clocked through a shift +0 AAAA AAAA 

register and control the new bits which end up in the syndrome shift +E E8F1 0391 

register. The CRC checksum is produced after 16 clock periods cor- +E EBO9 0391 


responding to the 16 data bits. A hex value of 198H is added to the +E EB49 0391 
checksum using the XOR function which simplifies the synchroni- LE VAIN 
sation process at the receiver site. The 10 check bits are sent after 

the 16 data bits. This technique is very similar to the standard RDS aE An NIN 
system described in [8]. +E EB41 0391 

When the receiver knows where a new block starts it computes the +0 5475 2980 time= 18:38 week=07 day=02 tuesday 
syndrome (in exactly the same way as the transmitter) of the fol- +E EB29 0391 

lowing 16 data bits and compares it with the 10 CRC bits follow- 
ing the data. In order to find the start of the block it is necessary 
to check each time a new bit is received whether the previous 26 
bits produced an error-free combination of 16 data bits and 10 Listing 4: Transmitter CRC calculation 
checksum bits. This test produces an ‘OK’ ata spacing of 26 bits SENG Kw AG) 
while receiving a continuous data stream. Occasionally an ‘OK’ will 


= 
7 


occur in an incorrect position. The block synchronisation algorithm ayn fol 

looks for a pattern with three ‘OK’ signals spaced by 26 bits. When WOE MISO O se) 

this is detected it assumes that the block start has been correctly Syndrom=Syndrom<<1l ; // outgoing bit is at mask 
identified. 0x0400 

Figure 9 shows schematically how the check bits are continuously if (w & 0x8000) 4 

calculated. The syndrome calculator can be looked on as a type of Syndrom ^= @x0400 ; // xor into outgoing bit 


filtering. The feedback shift register is configured in the same way i 
as the one used in the transmitter path. The continuous stream of 
bits are processed and as each bit emerges from the 10+16 bit shift 
register it is taken into account in the syndrome shift register. The 


w=w<<l1 ; 
if ( Syndrom & 0x0400 ) { 


software need only check if the syndrome shift register contains Syndrom ^= 0x1B9 ; 

the value 198H which was the value added during encoding at the } 

transmitter end. When this value is found the software responds } 

with an ‘OK’. A counter called ‘localTime’ is incremented from zero Syndrom=(Syndrom*ofs)<<6 ; 


to 25. A value of zero indicates that a complete block together with 
the check bits have been processed. 


SendBits(Syndrom,10) ; 
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Data (16 bits) 
Qa 


16-bit data register parallel-in, serial-out 


0x01B9 = 0b000110111001 
= 9876543210 


Q(x) =x^10 + KAB + X^7 + X45 + YM + X43 + X40 


Figure 8. CRC1. 


To demonstrate this behaviour, a variant of the receiver was pro- 
grammed so that the actual time (localTime) is output as a saw- 
tooth waveform from the PWM-DAC output. The second PWM 
DAC output will be high when the synchronisation circuit detects 
an ‘OK’. The repetitive waveform can be seen in Figure 10. Also vis- 
ible is a position where a false ‘OK’ is detected. It is may be neces- 
sary to wait a little before this random event happens. 

After synchronisation when the ‘OK’ occurs at the time interval zero 
it indicates that error-free block has been received and the data can 
be output. With this the data reception process is complete. 

This description of synchronisation applies for the BBC long wave 
transmission on 198 kHz. The data sent by the BBC does not how- 
ever contain RDS parameters but uses blocks of data containing 47 
data bits with a 13-bit checksum. The data is described in detail in 
the documentation [7] and is relatively easy to extract. In particu- 
lar, for simplicity the time-of-day information is simply coded in one 
complete block. 


BBC648 AMSS reception and decoding 

This last exercise was intended to demonstrate data reception 
from the European World Service signal which the BBC transmits 
on 648 KHz. In the mean time due to budget cuts transmission on 
this frequency has sadly been discontinued. It is however instruc 
tional to demonstrate how the AMSS data is decoded in this case. 
Up until recently the BBC sent low frequency AMSS data as part of 


Listing 5: BBC 648 kHz signal: AMSS SDC data 


[6 1]BBC WS 
[6 1]BBC WS 
[6 1]BBC WS 
[6 1]BBC WS 
[6 1]BBC WS 


[C B] 
[C B] 
[C B] 
[C B] 
[C B] 


[6 B] 
[6 B] 
[6 B] 
[6 B] 
[6 B] 


0/7+ 1/7+ 
0/7+ 1/7+ 
0/7+ 1/7+ 
0/7+ 1/7+ 
0/7+ 1/7+ 
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its 648 kHz AM transmission (see the associated literature [10]). The 
front end of our receiver samples at 20 MHz / 1,875 = 10,666... kHz. 
This results in an intermediate frequency of: 


648 kHz - 61 x 10,666... kHz = -2,666... kHz = 0.25 x 10,666... kHz. 


Bi-phase signalling is used with a phase modulation of +20°. 

With regard to the modulation and bit-coding method used by the 
data traffic it is (almost) identical to 198 KHz system described ear- 
lier. The difference here is that each block consists of 36 message 
bits and 11 CRC check bits. Two blocks form a group and a defined 
number of groups form a DRM-SDC block. A complete description 
of all the features is available in the DRM specification. Our simple 
receiver only extracts and displays the name of the transmitter sta- 
tion but is, never the less, a fully functioning data receiver. 

Listing 5 shows the receive data. The output ‘2/7+’ indicates that 
the second group from seven has been received with no detected 
errors. The data is decoded when all seven groups have been 
received. 


And finally... 

This now brings to a close the six-part series on signal processing 
and ‘Software Defined Radio’ using AVR microcontrollers. It has 
powerfully demonstrated just what can be achieved with even rel- 
atively modest microcontrollers. Commercial SDR receivers employ 


6/7+ 7/7+!0007 ; 
6/7+ 7/7+!0007 ; 
6/7+ 7/7+!0007 ; 
6/7+ 7/7+!0007 ; 
6/7+ 7/7+!0007 ; 
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0x01B9 = 0b000110111001 
= 9876543210 


Q(x) = x10 + KAB + KAT + x^5 + xM + x^3 + XAD 


X26 = 0b000110111001 
= 9876543210 


16 data bits 
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10 check bits 


Figure 9. CRC2. 


exactly the same techniques as detailed here; the only difference 

is that they use more powerful DSPs and radio front-ends which of 

course also makes them correspondingly more expensive! 
(120392) 


Internet Links 

[1] www.elektor.com/100180 

[2] www.elektor.com/100181 

[3] www.elektor.com/100182 

[4] www.elektor.com/120088 

[5] www.elektor.com/120089 

[6] www.elektor.com/120392 

[7] http://downloads.bbc.co.uk/rd/pubs/reports/1984-19.pdf 
[8] ftp://ftp.rds.org.uk/pub/acrobat/rbds1998.pdf 

[9] www.drm.org/ 


[10] www.ebu.ch/fr/technical/trev/trev_305-murphy. pdf 
www.broadcastpapers.com/whitepa- 
pers/ABUBBCamss2006.pdf?CFID=1 
6508900&CFTOKEN=dac28b1a87e5 
4d77-47F9A337-9A30-F5E3-667FAB2A9EA27223 


Elektor products and support 


e Signal generator (Kit with PCB and all components, # 100180-71) 
e Universal receiver (Kit with PCB and all components, #100181-71) 


e Active ferrite antenna (Kit with PCB and all components, # 
100182-71) 

e Combi-kit with all three components plus USB/TTL converter BOB 
FT232: #100182-72 
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Figure 10. The OK signal. 


e USB/TTL converter BOB FT232, fully populated and tested, # 


110553-91 
e Free software downloads (hex files and source code) 


All of these products and downloads are available through the web 
page: www.elektor.com/ 120392 
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TEST & MEASUREMENT 


Picoammeter 


By Burkhard Kainka (Germany) 


It is often necessary to deal with 
tiny currents in the picoamp to 
microamp range when making 
measurements in ionisation 
chambers and other radiation 
sensors, as well as when testing 


insulation. 


The instrument described here can be used 
to measure currents from around 0.1 pA to 
1 uA, without the need to change range. 
One approach is to exploit the logarithmic 
characteristic curve of a silicon diode, with 
the diode voltage buffered by a type TLC272 
CMOS opamp. For the first experiment we 
used a 1N4148 silicon diode (see l/h circuit). 
However, the lowest current measurable 
using this arrangement was over 10 pA, as 
below that value the diode’s characteristics 
deviate from the logarithmic curve. 


A particularly good diode with a very low 
reverse current is the gate-source diode 
inside a BF245 JFET (see lower circuit). 
Using this we can measure currents of less 
than 1 pA. To calibrate the circuit we use 
known currents at the input and measure 
the output voltage: 





The above values closely follow a 
logarithmic curve: each increase in current 
by a factor of ten gives an output voltage 
increment of 70 mV. We have already 
covered four decades: the graph shows how 
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the curve can be extended to even lower 
currents. 

Experiments show that it is even possible to 
get useful results with currents of less than 
1 pA. In this case, however, it is essential to 
carefully screen the whole circuit, including 
the item under test, against the effects of 
external fields. For the prototype a metal tin 
was used with feed-throughs. 


Some results obtained with the prototype: 
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e ionisation chamber with a sample of 
pitchblende: about 1 pA; 

e BPW34 photodiode used as a radiation 
detector (in complete darkness): about 
10 pA; 

e burnt-out filament lamp: about 100 pA; 

e burnt-out halogen lamp: about 0.1 pA. 


From these last two results we can see 
that quartz glass is a considerably better 
insulator than ordinary glass. 

(120322) 
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By Jens Nickel 
(Elektor Germany Editor) 


Good news for all automation 
enthusiasts in general and Elek- 


torBus friends in particular: more peerage nec 
bus hardware is in the pipeline, T 
including a larger Xmega board s PB2JOC1B 
with display and web server 
module that you can use as a R 
control centre. The C firmware ee ee 
library is on the way. More at PCHIADC! PD1/TXD 
www.elektor-projects.com! Wa cae 
z P J b; PC3/ADC3 PD3/INT1 


PC4/ADC4/SDA PD4/T0 


Meanwhile, here’s a small E-Labs 

. 3 ; PC5/ADCS/SCL PD5/T1 
Inside instalment, hopefully with ee ete 
yet more educational value. AREH ERLE 


When we designed our RS485 GND GND XTALL_XTAL GND 
relay Board [1] an extra access 
point was provided to the RS485 
driver’s signal ground (SIG_GND 


S C4 C6 


= signal ground). The idea was to be : 
pass on the RS485-driver ground | 
via an additional line run from 


100n =| 4u7 


node to node, in parallel with 
the ElektorBus ground for the 
supply of each node (GND). This 
was explained in the article: 
“When loads are switched it is pos- 
sible that there will be local inter- 
ference generated on the bus ground; and if the ground poten- 
tials at the drivers differ too widely this can result in spurious bits 
being detected on the bus. One solution might be to connect signal 
ground directly to bus ground at only one point on the bus, while in 
the other bus nodes the two signals are linked via (for example) a 
100 Q resistor. ... We have not yet tested this possibility...” 


We received an email on this subject from Elektor reader 
Andreas Schoenberg, who has been professionally engaged 
with RS485 bus systems (among others) for about 25 years. 
Our desire to have a “reference ground” that’s always at the 
same level for all the bus drivers, appeared reasonable. However 
with the LT1785 the common-mode voltage at A/B is allowed 
to be in the range of -7 to +12 V (w.r.t. ground). Even when the 
ground potentials of two bus nodes differ by 7 V, all bus levels 
would still be interpreted correctly. Andreas Schoenberg con- 
tinued, “Statically this cannot occur in the circuit. If 7 V appears 
to drop on the GND line to some high-current bus node, then 
an equal amount applies to the supply line, meaning a total of 
14 V would be lost.” Surely that’s not possible, because the bus 
supply voltage is only 12 V. He continued: “Dynamically, it cer- 
tainly looks different — if a relay is energized in a module, this 
can cause a short voltage dip. If so, this should be counteracted 
with local capacitances at the supply pins of IC3. Provided suffi- 
cient local buffering is available, I believe that ground shift prob- 
lems cannot occur in your system or in the transceivers used, to 
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the extent of disrupting the communication.” 


However, if you actually have a bus node that draws so 
much power and/or is connected using long, thin wires, 
that GND is at 3 V above SIG_GND due to a voltage drop, 
other problems can be expected. The LT1785 at its Vcc 
pin invariably ‘sees’ a voltage that’s 5 V above the local 
GND potential — hence in this case it is powered at 8 V. 
However the DE pin is pulled to GND via R3, and DE cannot be 
pulled lower by the CPU because that too is referred to this 
ground potential only. For the transceiver however, that’s still 3 
V above its own ground connection (SIG_GND), i.e. always High. 
The Driver Enable pin is then out of control by the software! 


So much for theory. It would be interesting now to know how 
you got along with the wiring of the ElektorBus hardware and 
if you ran in to any problems. Here at Elektor we already estab- 
lished that the communication is very robust, even with long, 
el-cheapo cables and four lines [2]. Which cables did you use? 
Tell us on editor@elektor.com 

(120501) 


[1] www.elektor.com/110727 
[2] www.elektor.com/120198 
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By Koen Beckers (Elektor Labs) 


Perhaps you’re familiar with this next problem: during com- 
munication between your PC and an AVR microcontroller in 
your new circuit the microcontroller resets itself abruptly for 
no particular reason. This happened to me while | was testing 
my design for a WiFi LED strip. 


Having tried several configurations and done a number of tests, 
| determined that it happened when | tried to have the micro- 
controller receive a large packet of data via its UART port. Some- 
times it seemed to work, but most of the time the microcon- 
troller was resetting itself and occasionally it crashed instantly 
after the transmission started. Very occasionally it kept reset- 
ting itself and the only thing to resolve this was to shut off the 
power supply. 


‘Consulting’ Dr. Internet, | learned this was a very common issue 
with AVR microcontrollers. Luckily a simple solution is available: 


E-Pollution! 


By Thijs Beckers (Elektor Editorial & Labs) 


As always testing and measuring is part of the daily lab activities 
and very rarely problems pop up of the really unexpected type. 
When fellow lab worker Ton Giesberts was testing a DCF77 
(European time signal) receiver for our popular AVR-SDR article 
series (series started in March 2012 edition [1]), he ran into 
some Serious issues. 


It proved plain impossible to receive the radio signal inside the 
lab. He even tried different locations inside our castle but to 
no avail. Admittedly, the castle walls are quite bulky (approx. 
80 cm, 2.5 feet) and may prevent the signal from entering, but 
even when the antenna was mounted on a 2 m (7 ft) long scrap 
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The UART connection needs to be fitted with a series resistor of 
10 kQ and a bypass capacitor of 100 pF essentially creating a low 
pass filter at about 159 kHz. 


My issues were with the reception of data, so | inserted a series 
resistor in the RX line and added a capacitor from RX to GND. A 
few lines of test code looping back the data received on RX to 
my PC (see the screenshot) confirmed the correct functioning 
of my circuit. All data got received correctly without the micro- 
controller crashing. 


Just to make sure it wasn’t my freshly written chunk of test 
code that fixed the problem, | removed the RC filter. Running 
my test code again resulted in an immediate crash of the micro- 
controller. After reinserting the RC filter all worked flawlessly 
again. | guess it’s safe to say this simple RC filter solved my issue. 
Perhaps it can solve yours too! 


(120386) 
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batten held out through a window so the antenna was well 
outside the castle walls, there was still zero signal. 

Suspecting the WiFi routers, PCs, laptops, fluorescent lighting, 
switching wall warts and DECT telephones could be interfering 
with the signal, Ton brought an old portable AM radio with long 
wave band reception from home and started walking around in 
the building, trying to receive the old faithful BBC4, the purpose 
of this being to find the most ‘silent’ place in the castle. This 
radio station transmits on long wave at 198 kHz. But nowhere 
in the castle did he find a sign of the signal. It was all dirt and 
noise — e-smog (Hey, didn’t we have a handily e-smog tester 
shortly? Yes, we had. It’s the TAPIR. Go check it out [2]!). Only 
after taking the radio more than 5 m (15 ft) outside of the castle 
walls, a weak signal of the station could be heard. 


When entering the building again — with the radio switched 
on — Ton noticed quite some interference signals when he held 
it next to the fluorescent lighting. Turns out they generate 
quite some noise exactly in the 198 kHz range. So one (very) 
early Monday morning, when there were very few staff present 
and all the lights were still off, he tested again. But still there 
was far too much noise coming from PCs, WiFi-routers, DECT 
telephones, printers and other electronics that never goes 
silent. 





v SS 


So much for testing sensitive equipment inside the castle. A 
proper worst case scenario test though; when a circuit passes 
testing inside our labs, it sure is interference-proof... 


Fellow lab worker Luc Lemmens experienced the same problems 
with a design soon to be released. He decided to take his 
testing matters elsewhere: home. As soon as he powered up 
his prototype (also with a DCF77 receiver) everything came to 
life and functioned as it should — right out of the box! 

Ton ended up sending the prototype to an esteemed external 
author for testing. And it worked instantly when he tested it. So 
the lesson to be learned is: Do you want to test a prototype with 
radio receiving capabilities? Don’t be too disappointed when it 
doesn’t work when testing it in your lab environment. Chances 
are your circuit works a treat, but e-smog from your electrical 
devices is interfering with the reception of the signal. 


(120504) 


Internet Links 


[1] www.elektor.com/100180 
[2] www.elektor.com/ 120354 


Your all-time favourite component 


By Thijs Beckers (Elektor Editorial & Labs) 


As an electronics engineer you often get to deal with electronic 
as well as electrical components. Some are new and just hit the 
market, others are old and have been here for ages. 


Like with so many things, you probably have your own preferred 
voltage regulator, Schottky diode, microcontroller, capacitor 
type or even vacuum tube. But with vast numbers of Elektor 
readers out there, there are bound to be differences. So here’s 
a call to explain to us why this Gunn Diode you always refer to 


is your favourite. Tell us your experiences with that BRY39 and 
elaborate on your favourite IC. Does the LM729 hold any secrets 
for you? And why do you still use that 6502 for almost every job? 


We look forward to a flood of emails in our inbox (myfa- 
voritepart@elektor.com) and hope to be surprised by strik- 
ing stories and notable narrations on your preferred electronic 
component. 


(120503) 
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COMPONENT TIPS 


Energy Harvesting with the LTC3108 & LTC3588-1 


Imagine you have a sensor, which only has to report its results very infrequently and is located far away. A direct power supply is not practical be- 
cause of the distance, a battery does not last forever and will eventually have to be replaced. Now what? Energy harvesting! Modern sensors can 
be very frugal and just like small microcontrollers they often have a power-saving mode of operation. If the average energy requirement in this 
power-saving mode is very small, then it would be possible to charge a capacitor during this long interval. This capacitor can then power the sen- 
sor for a brief moment, after which it returns to a sleep state. During this sleep state the capacitor is charged once again. Below | describe two ICs 
capable of deriving energy from various ambient sources. The LTC3108 is specifically intended to operate in combination with a Peltier element. 
The LTC3588-1 is more suited for piezo elements. A circuit idea could be to power the ams lightning detector from last month, together with a mi- 


By Raymond Vermeulen (Elektor Labs) 


crocontroller and RF module, using energy harvesting. 
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LTC3108 


The LTC3108 can obtain energy from voltage sources that supply 
very small voltages, starting from about 20 mV(!). This enables 
the use of a small Peltier element with only a very small tempera- 


ture differential. The manufacturer’s datasheet lists a number of 
other potential sources. The operation is the same as that of a 
boost/step-up converter with an adjustable output voltage. 


An LDO with an output of 2.2 V is also present. There is an ad- 
ditional Vout output that can be switched on and off and can 

be used, for example, to power a small circuit that needs to be 
turned on only very briefly and does not have to be placed in 
some kind of power-down mode. An alternative to this chip is pos- 
sibly the bg25504. 


LTC3108 Datasheet 
http://cds.linear.com/docs/Datasheet/3108fb.pdf 

















Figure 2. Application example using a Peltier element. 


LTC3588-1 


The LTC3588-a can obtain energy from a piezo element, but also, 
for example, from two metal plates positioned close to a fluores- 
cent light tube. The datasheet offers additional options. A piezo 
element can generate a relatively high voltage, this is internally 
limited by the IC to 20 V. This voltage is then reduced to an ad- 
justable voltage by a buck/step-down converter. 


The prescribed piezo-element in the datasheet is very expensive, 
but perhaps the IC will also work in combination with a piezo 
buzzer? If so, is it possible to obtain sufficient energy? This is an 
invitation for some experimenting! 


LTC3588-1 Datasheet 
http://cds.linear.com/docs/Datasheet/35881 fa. pdf 


Figure 4. Application example using a piezo element. 
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Arduino on Course (2) 
Part 2: read (awfully) remote sensors 


using GSM / GPRS 


This month we’ll explore the 
possibilities offered by GSM 
and GPRS communication for 
your projects. We will 

link concepts like the 
Internet of Things (loT) 

or the Machine To Machine 
(M2M) business in order to 
understand what you can achieve 


all by yourself in a short time. 
By David Cuartielles (Spain) 


Shopping list 
In terms of hardware, here’s what you need to be able to replicate 
the experiment discussed in this instalment: 


e Arduino Uno board; 

e Arduino GSM shield (made in collaboration with Telefonica I+D); 
e a SIM card for the GSM/GPRS network; 

e a cellphone (‘mobile’) with its own SIM card; 

e TinkerKit shield; 

e TinkerKit LED module (x3); 

e TinkerkKit Slider module. 


The last three items in the list can be substituted by a breadboard 
and a combination of various components. However, to keep the 
focus on the operation of the GSM library for Arduino, | have opted 
to use pre-assembled parts. 

Now, before you read on, | strongly recommend you download all 
the code used this month. Due to the length of the example pro- 
grams, only excerpts are printed here. 


Introduction to M2M and loT 

Putting it in easy terms, loT is a computing paradigm that is being 
explored lately by many research laboratories and universities 
around the world. It tries to bring to life the idea that everything can 
be connected to the Internet: your microwave and your car, passing 
by your door lock and your bike at the gym. All those objects should 
be able of talking to each other in some way and exchange data to 
offer people better ways to handle different situations. 

Ericsson, the Swedish communication giant, presented a memo 
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[1] last year where 
they envisioned that 
by 2020 there would be 50 
billion connected devices. That 
would mean that most of our home 
appliances are connected to the Internet: 
fridges and microwaves, alarm clocks and TVs, 
the elevator and the stove. But also all the other devices that 
surround us like cars, streetlights, or shopping carts (the push- 
able type, not the icon or applet). 
M2M (machine-to-machine) is concerned with the connectivity 
between devices using wireless, wired or hybrid communication. 
In a sense, M2M makes loT (Internet-of-things) possible as it offers 
the infrastructure for devices to gather data and transmit it through 
a network to a remote location. For some people M2M is a synonym 
of telemetry in whatever form, but in recent years the concept has 
mutated to refer mostly to wireless communication and to be more 
specific it is mostly referring to the use of cellular (mobile) commu- 
nication for remotely controlling devices. 


For the sake of simplicity, when talking about the loT | mean the 
connection of devices to the Internet, while M2M will be a way to 
make this possible through the cellular telephony network. You 
will find many articles and videos on the Internet that follow the 
Same approach, the reason being that the most extended net- 
work right now is the one called GSM (global system for mobile 
communications). 

| assume that you are reading this article because you plan on mak- 
ing a connected device. Imagine that you create an object that’s 
going to connect to the Internet and send data back to you from 
anywhere in the world — what, do you think, is the best way to do 
so? The answer is obvious: cellular telephony. GSM is a great alter- 
native as it allows you contact your device almost anywhere in the 
world knowing that it will work, basically like at home. 


The Arduino - GSM/GPRS Shield 

From Arduino we want to simplify as much as possible the way 
you build prototypes and learn about technology. Therefore we 
have spent quite some time thinking about how to help you get- 
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ting hooked to this trend of loT in many ways. One of them is 
through M2M and for that we teamed up with Telefonica’s Physi- 
cal Internet Laboratory. 

We have been collaborating in making an official Arduino shield that 
easily handles GSM/GPRS (also known as 1G and 2G) communication. 
We also wrote a library that simplifies the process of texting (SMS 
transmission), setting up calls or publishing some data on a website. 
The design is open source and the software can easily be ported 
to support other shields (with potentially other series of AT-Com- 
mands; more about this later). Finally, the shield comes with a SIM 
card, courtesy of Telefonica, that will offer you the possibility to 
hook up to send/receive text (SMS), set/get voice calls, and con- 
nect to the Internet through the GPRS network. 


Note: This shield is not locked to the accompanying SIM; you could 
use any other GSM/GPRS SIM card available in your country. The 
SIM is optimised for data communication; if you wanted to make 
something controlled over Text (SMS), you should consider a SIM 
card operating on your preferred network. If you were about to use 
the card coming with the board, you should follow the online acti- 
vation instructions that come with it. 


Controlling a modem - AT commands 

Modems are the devices behind the expansion of the Internet. In 
order to automate the way they would operate, a company called 
Hayes [2] invented in 1981 what would later be called the AT-Com- 
mand Set. The idea behind it all is for modems to change between 
Command and Data operation modes. The Command mode would 
allow performing operations on the modem itself like calling a cer- 
tain number, changing the baud rate (the speed at which the data 
would be transferred), etc. 

The Hayes Command Set became a de-facto standard for the way 
devices should communicate over a serial port. That standard is still 
operating inside many devices. When in Command mode, devices 
start the communication sending the string “AT” which stands for 
“attention”. That would be followed by other strings that would 
translate in different operations to be performed at the other side. 
On the other hand, when in Data mode, the data will just be proxied 
to/from the Internet through the modem. 

The GSM/GPRS shield has a radio modem manufactured by Quec 
tel [3] that can be operated using a series of AT commands. Most of 
those commands are specific to the modem on the board, but the 
library that controls the shield has been written in a way that makes 
very easy to port it for other modems made by any manufacturer. 
Also, the library hides all the complexity behind this mode of opera- 
tion. Therefore, we are not going to refer to them in the rest of the 
article. However, if you happened to use the GSM library in debug 
mode, you would be prompted with many of those commands. 


Installing the GSM Library for Arduino 

At the time of writing this article the Arduino IDE had reached revi- 
sion 1.0.1 and did not include the GSM library we’re about to dis- 
cuss. Thus, when checking the menu ‘Sketch / Import Library’ if you 
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don’t see the library named ‘GSM3’ in the list, you will have to down- 
load it from the official Arduino website hosting this project [4] and 
install it as explained under the ‘Library’ link. Essentially, adding a 
new library to the IDE is done by creating a folder called ‘libraries’ 
inside your sketchbook and uncompressing the file you got from the 
website [4] directly there. After that, you should restart the Arduino 
IDE and the library will then show up in the above mentioned menu. 
With the library you will be installing not only the code to execute 
different commands on the modem, but also a series of examples 
that will allow you to: 


e test whether the modem is working properly; 

e text, i.e. send/receive SMS; 

e place/get phonecalls (voice); 

e open a TCP/IP connection and exchange data over the Internet, 
using GPRS; 

e post/collect sensor information to/from Cosm (an online data 
service); 

e collect and show twitter messages. 


The way to access the examples is simple: just use the menu to navi- 
gate through “File / Examples / GSM3”. 


Checking your status 

Likely, the first thing you want to do is checking whether your board 
is working properly and whether your SIM card can be used by the 
shield for you to experiment with. To do so, open the example under 





// libraries 
#include <GSM3ShieldV1ModemVerification.h> 


// modem verification object 
GSM3ShieldV1ModemVerification modemTest; 


// IMEI variable 
String IMEI = “”; 


// serial monitor result messages 
String oktext = “OK”; 
String errortext = “ERROR”; 


void setup() 
{ 








// initialize serial communications 
Serial. begin(96@Q) ; 


// start modem test (reset and check response) 
Serial.print(“Starting modem test...”); 
modemTest.begin(); 

Serial.println(oktext) ; 
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void loop() 

{ 
// get modem IMEI 
Serial.print(“Checking IMEI...”); 
IMEI = modemTest.getIMEI(); 


// check IMEI responsed 
if(IMEI != NULL) 
{ 
Serial. println(oktext) ; 
// show IMEI in serial monitor 
Serial.println(“Modem’s IMEI: “ + IMEI); 
// reset modem for check booting 
Serial.print(“Reseting modem...”); 
modemTest.begin() ; 
// get and check IMEI one more time 
if(modemTest.getIMEI() != NULL) 
{ 
Serial. println(oktext) ; 
Serial.println(“TEST COMPLETE!”); 
} 
else 
í 
Serial.println(errortext); 
} 
|| 
else 
{ 
Serial.println(errortext); 


l 
while(true); 


the menu: “File / Examples / GSM3 / Tools / TestModem”. 


This code example allows you to check whether Arduino can detect 
your radio modem. It also opens a connection to the radio modem 
on your GSM shield and attempts to read the IMEI (International 
Mobile Equipment Identity) from it — that’s a unique number for 
every device capable of connecting to the GSM/GPRS/3G/4G net- 
work. For example, your cell phone identifies itself via the IMEI. 
Every device on the GSM network has a unique ID. If everything goes 
fine, after uploading the example on your Arduino Uno, and opening 
the Serial Port Monitor, you should see something like in Figure 1. 
If your modem was working correctly, the next thing is to check 
whether you can connect to the GPRS network. To do so, we will 
open the example: File / Examples / GSM3 / Tools / TestGPRS. | will not 
show the code here, as it is very similar to the previous one. This 
example is used for testing that your SIM card allows connecting to 
the GPRS network (the one provided with the shield does), but also 
to test your settings. 


Note: this shield is using GSM/GPRS technology and not 3G. 3G and 
GSM SIM cards look the same, but remember that some of the mod- 
ern operators do not offer 2G (the way we call GPRS) services. 
Connecting to the GPRS network calls for a tad more configuring 
than just texting (sending an SMS) or placing a call. There are four 
parameters that need to be configured: 


e APN: acronym for Access Point Name or the name of the 
domain the shield will connect through to reach the Internet. 
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Figure 1. Positive answer from the TestModem example using the 
Serial Monitor. 
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Figure 2. Configure your GPRS connection using the Serial Monitor. 


It is specific for the operator providing you with connectivity 
through the shield; 

“ login: some operators require a login; 

e password: some operators require a password; 

e proxy: this is the address to a server that will channel all your 
communication inside the operator’s network. Most likely it 
won’t be used. 


The way this example works is by asking you for the information the 
shield needs to connect to the network. 


Tip: remember activating the option ‘Newline’ in the dropdown 
menu at the bottom of your Serial Port monitor. In this way, when 
clicking on ‘Send’ on the monitor, the system will add an end-of-line 
(EOL) character that is needed for the modem to know the informa- 
tion package came to an end. 

| everything goes fine, you will see a window like in Figure 2. Those 
messages mean that your shield can connect to the Internet using 
your SIM. Please note that even if you couldn’t connect to the Inter- 
net, it may still be possible for you to text-out, get text (send/receive 
SMS) and set up calls. 


Texting (sending an SMS) 
Texting or receiving text (sending or receiving SMS) with the GSM 
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Figure 3. Screenshot of my phone after | was texted. 


// send the message 
sms .beginSMS(“@755442200”) ; 


sms.print(“hola caracola”); 
sms .endSMS() ; 





shield couldn’t be any easier. The following lines of code could be 
part of a program sending a string to a certain number. 

Note that | am using a fictitious cell phone number! And the result 
on the screen of my phone would be like shown in Figure 3. 

The library comes with examples covering both sending and receiv- 
ing. For example, the code at File / Examples / GSM3 / Tools / SendSMS 
will be sending an SMS (texting out) from the board to a phone via 
interaction through the Serial Port Monitor. It will first ask you for 
the phone number to text to (SMS) and then for the string to send. 
Try it out! 


Remotely controlling a device via Text (SMS) 

Controlling a device remotely implies receiving messages, parsing 
the data, and operating actuators depending on the different com- 
mands. In this case we are going to build a quick prototype includ- 
ing three LEDs: one red, one green and one blue. You can imag- 
ine that instead of using LEDs we could be attaching relays, and we 
could be controlling any kind of device on distance. The program 
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is going to read the first character sent in the SMS and turn on the 
corresponding light: R for red, G for Green and B for blue. This pro- 
gram is, as you can see, very simple. It doesn’t execute huge parsing 
operations; it simply reads the first character in the text message 
(SMS) and decides what to do. After that, the text message (SMS) 
will be erased from the memory using the command sms. flush(). 


// If there are any SMSs available() 
if (sms.available()) 
{ 


Serial.println(“Message received from:”); 


// Get remote number 
sms. remoteNumber (remoteNumber, 20); 
Serial.println(remoteNumber) ; 


// This is just an example of message disposal 
// Messages starting with # should be discarded 
if(sms.peek()==’ #’ ) 
{ 

Serial.println( “Discarded SMS”); 

sms. flush(); 


} 


// Read message bytes and print them 
int count = 0; 
while(c=sms.read()) { 
if(!count) { 
digitalWrite(pinR, LOW); 
digitalWrite(pinG, LOW); 
digitalWrite(pinB, LOW); 


switch(c) { 
case ‘R’: 
digitalWrite(pinR, HIGH); 
break; 
case ‘G’: 
digitalWrite(pinG, HIGH); 
break; 
case ‘B’: 
digitalWrite(pinB, HIGH); 
break; 
J 
} 
count++; 


I 


Serial.println(“\nEND OF MESSAGE”); 


// delete message from modem memory 
sms.flush(); 
Serial.println( “MESSAGE DELETED”); 
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Figure 4. All in hand: Arduino Uno + GSM/GPRS shield + 
TinkerKit shield + TinkerKit LED. 





The following is a part of the example DecodeSMS you can find at 
the download link [5] for this article. 
The actual circuit boards are shown in Figure 4. 


Device working over GPRS 

Let’s now see how to use an analogue sensor (a slider in this case) and 
send data from it to a website. On the server side | am using Apache 
and avery simple PHP script that will be taking the data sent by the 
board and will update a part of the script containing plain HTML. This 
is what I like to call a simple ‘online memory cell’. It is a PHP script 
that can take the data and display it. It will be possible to access that 
same page using a browser to see the data changing over time. You 
will need to use the same APN/login/pass combination you used in 


void loop() 

{ 
client.connect(server, 80); 
Serial.println(“sending data...”); 
client.print(“GET “); 
client.print(path); 
client.print(query); 


client.print(analogRead(A0)); // take the value 


// on A® and send it 
client.println(“ HTTP/1.1”); 
client.print(“HOST: “); 
client.println(server); 
client.println(); 
client.stop(); 
delay (10000); 


the previous GPRS example for this code to work properly. Here’s how 
to send an analogue value to a server every 10 seconds: 

You need to have a server to run the php code that will be reading 
from your Arduino board. The server needs to be publicly accessible 
as you want your Arduino board to post information to it and to read 
that data using a browser, a phone or any other web-enabled device. 
Important: keep in mind that this code is just a proof of concept, it is 
not safe in any way and you should probably disable the PHP script 
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Figure 5. Information being displayed on a browser as sent from 
the GSM shield. 


once you are done trying out the example. 

The only thing left to do is uncompress the code of the PHP mem- 
ory cell in the given file [5] at the root folder, to your http server. 
Make sure the file has read-write-execute permissions to allow it to 
rewrite itself. You can then type the URL to your server (for example: 
http://server.com/path/index.php) in a browser to see the informa- 
tion update every 10 seconds. Like in Figure 5. 


Closing words 
| hope you found this brief introduction to the use of GSM/GPRS 
technology in your projects both educational and fun. | want to 
highlight how relevant it is that we, as makers, can benefit from 
the existence of an omnipresent wireless network. If you don’t need 
very data-hungry devices, you could start controlling lots of things 
over the cellphone network. As long as there is a way to power up 
your board, you can gather and process data from almost anywhere. 
(120506) 


Internet Links 


[1] Ericsson’s memo on 50 billion connected devices: 
www.ericsson.com/res/docs/whitepapers/wp-50-billions.pdf 


[2] onthe AT-Command set: 
http://en.wikipedia.org/wiki/Hayes_command_set 


[3] Quectel AT-Command description: 
http://datasphere.eu/en?t=/documentManager/sfdoc. file. 
supply&filelID=1285079825955 


[4] Arduino website hosting information about the GSM shield: 
http://labs.arduino.cc/GPRS/Index 


[5] Compressed file with all the examples and images: 
www.elektor.com/120506 
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Radiation Meter Reloaded 


Simple modifications open up 








new possibilities 


By Burkhard Kainka (Germany) 


The radiation meter published in the 
November 2011 edition of Elektor is 


currently being used by many readers, 


mainly in making long-term 


measurements and in investigating 


weakly radioactive samples. There 


are several ways in which we can 


modify and improve the design, and we 


look here at a few examples. 


The ‘Improved Radiation Meter’ was pub- 
lished in Elektor in November 2011 [3]. The 
device is available as a kit of parts [2], the 
ATmega88 microcontroller being equipped 
with a bootloader that makes it easy to pro- 
gram your own code into it. Some applica- 
tions will require just a small change to the 
code in the basic program, and below we 
will look at a couple of examples of this. 
Other applications will require firing up the 
soldering iron to make more permanent 
changes: we will look at some of the pos- 
sible hardware modifications first. 


Calibration 

The following question often crops up in our 
readers’ forum: can the radiation meter be 
calibrated in standard units such as micro- 
sievert per hour (uSv/h)? This turns out not 
to be so easy, as several variables enter into 
the equation. The most significant of these 
is the screening used. 


Experience with the radiation meter shows 
that it is not easy to screen the sensor com- 
pletely from light without simultaneously 
also blocking the radiation we are inter- 
ested in to a significant extent. Two options 
are open to us: we could put the sensor and 
the sample being studied together in a 
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metal can connected to ground, or we could 
wrap the whole sensor board in aluminium 
foil, which again must be grounded. Some 
readers have experienced problems with 
the latter approach arising from a microph- 
ony effect: the sensor forms a kind of con- 
denser microphone with the foil shield. The 
effect can be mitigated by gluing the foil 
directly to the sensor. Self-adhesive copper 
foil, 0.035 mm thick, has also been found to 
work well in practice: it also has the advan- 
tage that it is easier to solder the ground 
connection to it. 


We tried an experiment using a BPW34 
sensor with a copper foil shield. The radi- 
ation source was a thorium gas lantern 
mantle in its paper envelope. Because 
this source has a large area the radiation 
level at close quarters is approximately 
uniform, which means that the readings 
obtained are largely independent of the 
distance between source and sensor. The 
Flektor radiation meter gave approximately 
40 pulses per minute at a distance of 1 cm. 
For comparison we used a professional Gei- 
ger counter with a tube sensitive to beta 
and gamma radiation, again at a distance 
of 1 cm. This gave a reading of 800 pulses 
per minute, corresponding to 20 uSv/h. 





This gives us our first unofficial calibration 
result: 


1 pulse/min = 0.5 uSv/h 


In principle the unit is capable of measuring 
the level of background radiation if readings 
are taken over a sufficiently long period. 
Over very long periods it is possible to see a 
clear change in readings with variations in 
solar activity. The somewhat longer meas- 
urement period required than with a Geiger 
counter does of course make some applica- 
tions less practical: for example, if you try 
to measure the radiation from a salad you 
may well be lucky enough to discover that 
it is safe to eat, but by the time you know 
that your rocket will probably have wilted! 
The device is better suited to investigat- 
ing small, weakly radioactive, samples 
than to analysing the background radia- 
tion. Here the small sensor sizes gives the 
device an advantage over the Geiger coun- 
ter, as it makes it easier to discriminate 
between radiation from the sample and the 
background. 


AC coupling 


There is a further technique we can use to 
reduce the sensitivity to ambient light: we 
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Figure 1. AC coupling. 


can add AC coupling between the sensor 
board and the counter. A 100 nF capacitor 
and a 10 kQ resistor will do the job (Fig- 
ure 1). The circuit operates as a high-pass 
filter with a corner frequency of 160 Hz. It 
now does much less harm if light should fall 
on the sensor and shift its operating point. 
Flickering from artificial incandescent light- 
ing at a frequency of 100 Hz is also some- 
what attenuated. However, it does little to 
reduce the effect of fluorescent lights as 
these produce sharper flashes of light. Nev- 
ertheless, the filter modification does make 
the circuit more stable generally and con- 
siderably less sensitive to light. 


If desired, a potentiometer can be added to 
the circuit to allow adjustment of the coun- 
ter trigger threshold (Figure 2). Although 
this facility was already available in the PC 
software accompanying the design, some 
readers use the unit to make measure- 
ments ‘in the field’ without a PC attached: 


 Ulekior Alpha tamma Spectroscopy 


Figure 4. Calibration measurement using 
three BPW34s in parallel. 
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Figure 2. Setting the trigger threshold. 


if you are taking readings while scrambling 
around in a quarry, you will probably pre- 
fer not to risk lugging an expensive laptop 
about as well. The suggested circuit shifts 
the average threshold by up to 50 mV. 


By default the software sets the trigger 
threshold to 10, which corresponds to 
approximately 50 mV. At start-up the micro- 
controller measures the average voltage at 
its input and adds this value to the thresh- 
old: any pulse with amplitude exceeding 
this value will be counted. With the new 
AC coupling circuit the microcontroller 
will measure the average noise level on the 
input, obtaining, for example, a value of 5. 
The trigger threshold will then be 15. With 
the addition of the potentiometer the qui- 
escent level can be increased to as much 
as 50 mV. At start-up the potentiometer 
should be set to its lowest point. Then the 
threshold can be adjusted carefully towards 
the noise floor to determine the point 
where sensitivity is greatest. A press of the 
‘Zero’ button will then start a fresh series of 
readings with the new threshold setting. 


Sensors and results 

In its standard configuration the device uses 
a single type BPW34 PIN diode as its sen- 
sor. However, it is possible to wire several 
BPW 34s in parallel (see Figure 3). The effect 
of this is to produce meaningful readings in 
a shorter time. It is possible either simply to 
count the pulses or to use the more sophis- 
ticated program that analyses the energy 
spectrum. 














Figure 3. Three BPW34s in parallel. 


Before carrying out a measurement it is 
a good idea to do a calibration measure- 
ment to estimate the background radia- 
tion level. Figure 4 shows such a calibra- 
tion measurement with three BPW34s 
wired in parallel. The trigger threshold 
used was 5. Forty pulses of varying ener- 
gies were detected over the course of 
one hour. These results can be subtracted 
from the subsequent measurement to 
improve accuracy when using weakly 
radioactive samples. 


Potassium chloride (or more accurately the 
potassium-40 in it) exhibits weak beta activ- 
ity. Perhaps easier to obtain is potassium 
carbonate (or ‘carbonate of potash’), which 
is sometimes used in baking. A sample of 
this substance was placed in a small plastic 
bag next to the sensor. Figure 5 shows the 
results, taken over one hour. A total of 251 
pulses were counted, some six times the 
background level. 


= [lekiar Alpha tamma Spectroscopy 





Figure 5. Radiation from 
potassium carbonate. 
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Figure 6. A combination 
of different sensors. 


Alkaline batteries do not normally leak; 
however, when they do, the concentrated 
potassium hydroxide in them reacts with 
the CO, in the atmosphere to form potas- 
sium carbonate. This is seen as a white resi- 
due where the leak has occurred. This res- 
idue should be a weak radioactive source, 
and indeed this can be confirmed using the 
radiation meter. 

With the sensor set up for maximum sensi- 
tivity, including for low-energy pulses, we 
can use the radiation meter with samples 
of even lower activity. This can be seen in 
an experiment with charcoal ash from the 
barbecue, which contains potassium car- 
bonate. We measured a radiation level of 
approximately 150 pulses per hour from 
a sample. We can even find radioactiv- 
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Figure 7. Using a power transistor as an 
alpha particle sensor. 


ity in cigarette ash: in one experiment we 
obtained 80 pulses per hour, double the 
background level. Again, the main source 
of the radiation is probably potassium, 
although polonium, a product of uranium 
decay, may also play a part as it is accumu- 
lated in tobacco plants. 


Alpha decay 

Using an exposed BPX61 photodiode lets us 
also detect alpha particles. In fact, we can 
use both types of diode together: a BPW34 
to detect beta and gamma radiation, anda 
BPX61 for alpha particles (see Figure 6). 
To test this combination we first measure 
the weak radiation from a sample of potash 
or potassium carbonate and set the trig- 
ger threshold appropriately. Once this has 
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Figure 9. RS-232 level shifter. 
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been done successfully, we can move on to 
making the more difficult measurements, 
including on various building materials 
whose level of activity may be of interest. 
Alpha particles are distinguished by their 
higher energy: we can often find noticeable 
levels of radiation in plasterboard, because 
the gypsum used in its manufacture is made 
by the desulphurisation of flue gases from 
coal-fired power stations and, in turn, the 
coal contains a small amount of uranium 
and its various decay products. 


The 2N3055 as an alpha particle 
detector 

When alpha particles hit a silicon junction 
a relatively strong signal is produced. That 
is true not just for photodiodes, but for any 
type of diode or transistor. Under normal 
circumstances alpha particles do not get as 
far as the junction as they are absorbed by 
the devices package or shielding. However, 
we can get around this in the case of certain 
power transistors in a TO-3 package: if we 
remove the metal cap the silicon chip itself 
is revealed, with its relatively large surface 
are exposed to the elements. 

This is usually the case for the famous 
2N3055; for other devices there is some- 
times an additional protective layer, and 
so sometimes a little luck is needed to find 
one that is suitable. A fairly recently-pro- 
duced transistor from ST was found to work 
well (see Figure 7). The chip is completely 
exposed and makes an excellent alpha par- 
ticle sensor. Beta and gamma radiation, 
however, go completely undetected. Fig- 
ure 8 shows the result with a sample of 
pitchblende (uranite). When tested with 
an americium-241 source from a smoke 
detector more pulses were produced than 
the counter could cope with. 


Serial interface 

The counter board includes a three-pin con- 
nector which gives access to the serial port 
on the microcontroller, the RXD and TXD 
signals being at TTL levels. The connector is 
compatible with the Elektor breakout board 
(‘BOB’) [1], based on the FT232R, and so 
allows connection to a PC over USB using a 
virtual serial port. 

A very simple extension allows the device 
to be connected to a standard RS-232 inter- 
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face. Two NPN transistors do the job of shift- 
ing the voltage levels and inverting the sig- 
nals (see Figure 9). With this circuit you can 
connect the radiation meter to a PC with an 
ordinary serial port or to a USB-to-RS-232 
adaptor. 

The PCbased program can be installed to 
provide the ability to plot energy spectra 
and to adjust the trigger threshold. It also 
provides the additional useful function of 
uploading program updates (or even com- 
pletely new programs) into the microcon- 
troller over the serial port. 


Program upload 

Suppose we would like to make a change 
to the way the counter works. The boot- 
loader facility in the microcontroller makes 
this easy, and it even works with the ‘Demo’ 
version of BASCOM (Figure 10). First open 
the BASIC source code and then, after mak- 
ing any changes to it, compile it. 

Select the programmer to be used in BAS- 
COM. In this case it is ‘MCS Bootloader’. The 
COM port and baud rate (19200) also have 
to be set correctly (see Figure 11). 

Now start the programmer, for example by 
using the small green circuit board icon. The 
MCS Bootloader will now try to establish a 
connection with the microcontroller. 

The connection can only be established 
shortly after the microcontroller is powered 


Listing 1: Changes in Counter_1 


‘Print “Counter” 
Locate 1 , 1 
‘Led “Counter” 
‘Waitms 500 
Readeeprom L , 1 
If L = 255 Then L = 5 
U = @ 
For N= 1 To 1000 
D = Getadc(Q) 
U=U+D 
Next N 
U = U / 1000 


‘Um = Q 
UO = Um +L 
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up or reset. So, switch the device off and 
then on again, and programming should 
commence (Figure 12). 
When all the code has been uploaded the 
microcontroller immediately starts to exe- 
cute the new program. 


Software variants 

In-depth BASIC programming skills are 
not needed to make small changes to the 
program and to upload the new code to 
the microcontroller. Here are a couple of 
examples. 


1. Constant trigger threshold (Listing 1). 
Suppose we always wanted to have the trig- 
ger threshold equal to 5. All that’s required 
is to add the line ‘L = 5’ at the right point 
in the program. We can also get rid of the 
‘Counter’ message at start-up by simply 
commenting out the relevant lines by add- 
ing a single quotation mark at the begin- 
ning. A further change is also shown in List- 
ing 1, but commented out for now so it has 
no effect: the line ‘Um = 0’ sets the aver- 
age level to zero, which is better suited to 
use with the AC coupling circuit shown in 
Figure 1. 


2. Measuring the energy distribution 
(Listing 2) 
Our second example shows how to count 


Listing 2: Changes in Counter_2 


Do 
D = Getadc(Q) 
If D > Maxi Then Maxi = D 
Loop Until D < UQ 
Maxi = Maxi - Um 
If Maxi > 255 Then Maxi = 255 
N=N+1 
If Maxi > 40 Then N2 = N2 + 1 
If Maxi > 80 Then N3 = N3 + 1 


Locate 1 , 1 
Lcd N 

Led “ = 
Locate 1 , 8 
Led N2 

Locate 1 , 14 
Led N3 
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Figure 8. Measurement using an old faithful 
called 2N3055. 
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Figure 10. The BASCOM development 
environment. 
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Figure 11. Selecting the programmer. 
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Figure 12. Programming is successful! 
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pulses separately according to their 
energy. We will have three counters, one 
for all results (N), one for pulses with a level 
exceeding 40 (N2), and one for the highest- 
amplitude pulses, with a level exceeding 80 
(N3). All three counts will be displayed on 
the top line of the display. The values give 
a broad indication of the energy distribu- 
tion without the need to connect a PC to 
plot a graph. The fact that we can discrimi- 
nate energy levels in this way is a significant 
advantage of the semiconductor sensor 
over a conventional Geiger counter. 


Other substances to examine 

The question often arises of what sub- 
stances can be used to test the operation 
of the device. In the original article we sug- 
gested using a sample of uranite, a lumi- 
nous watch, and potassium chloride. Below 
we give a few more ideas. 

Uranium glass is still made. It is used in dec 
orative fluorescent glass beads. 

Type WT20 tungsten inert gas (TIG) weld- 
ing electrodes are made of tungsten with 
the addition of a 2% thorium oxide compo- 
nent. The electrodes are weak alpha, beta 
and gamma sources. 


Tungsten with added thorium is also used in 
the directly-heated cathodes of large radio 
transmitter valves, although admittedly 
such devices are not exactly found on every 
street corner. However, the same material is 
used in the magnetron in a domestic micro- 
wave oven: a salvaged magnetron cathode 
makes an effective test source. 

Thorium salts were used in the mantles for 
gas and paraffin lamps in the past, although 
modern mantles use different substances. If 
you can manage to get hold of an old man- 
tle, you will find it makes a particularly pow- 
erful test source, including of high-energy 
gamma rays. 

lonisation smoke detectors use a strong 
(perhaps 33 kBq) alpha source. Such detec 
tors are common in the USA and in the UK 
but much less popular in mainland Europe. 
The gamma rays produced by the substance 
are relatively weak, and so a BPW34 only 
produces about 30 pulses per minute. How- 
ever, the alpha particles also produced are 
easily detected by an exposed BPX61, giv- 
ing many thousands of pulses per minute. 
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Program the bootloader yourself 


If you programmed the microcontroller yourself you probably did it without the help of 
the bootloader. It is, however, possible to switch to using the bootloader. The program 

can be found along with the BASCOM development system examples, and requires a little 
adjustment to make it compatible with the ATmega88. The modified version is provided 
with the download files accompanying this article [2]. The compiled file BootLoader88.hex 
needs to be programmed into the 


microcontroller using (for example) SRS in ISP mode wilh A limepabe 


Man rogram! Fuses Lockie Advanced HW Setinge | HW Indy Audo 


the STK500 programmer, which 


Fut ka 
: i BUT 5 Boa Flash ares 1U reads Bool akkers- di 
will overwrite the counter program BODTAST 
: h FSTOMSBI 
already stored in the device. (We DWEN 
SPIEN 
will reload it later using the new- WDTON 
EESAVE | 
ly-programmed bootloader.) It is O Wanataka 
important not to use the hardware woun A 


SUT CKSEL int AC Osa, O MHz: Startap tine PWRIDWIMIESET: BOKAN CK « 65m T 
f 2 


programmer from this point on, as 


EXTENDED (hr 


otherwise the bootloader code will HIGH vie 
Lot" hE? 


be overwritten. Note also that the 
configuration fuses have to be cor- 


Fat read 
rectly set (see Figure): in particular E] Sman warming = 
[E] Verily aher pangeamming [Proce | [verte | [Feed ] 
the boot area must be enabled and 
its size set to 1024 words. When eve- || Wiraka edger Ot 2, MER DC. OFO., OK 
A [ih kheri Dlo 2. BEZ. (eC. DF. OK 





rything has been programmed cor- tee aba aenak Aan 


poping moe. UE! 
rectly, the counter program can be 


reloaded over the serial interface. 


Let us look in a bit more detail at the bootstrap process. When the bootloader is called up 
from within the development environment, the PC sends a continuous stream of bytes with 
value 123 and waits for the microcontroller to reply with the same byte value. Once com- 
munication is established all the programming data are transferred over the serial port and 
then programmed into the microcontroller’s flash memory. 


The microcontroller sees things as follows: upon reset or when power is applied it first 
branches into the boot area, an action enabled by the fuse settings mentioned above. The 
program stored in this area is responsible for determining whether a bootloader operation 
is required. If not, it branches to address zero and starts the program stored there. If, on 
the other hand, it detects the byte value 123 on the serial port, it echoes the byte and then 
waits to receive further data, which it writes into program memory. When programming is 
complete the new program is executed from address zero. 


Internet Links 


As you can see, a couple of simple modifi- 
cations to the radiation meter circuit open 
up a range of new possibilities. The kit [3] 
is easy to build as only leaded components 
are used. The Elektor BOB [1][2] is also rec 
ommended to simplify connection to a PC. 

(120381) 


[1] http://www.elektor.com/BOB 
[2] http://www.elektor.com/120381 
[3] http://www.elektor.com/110538 
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Electronics for Starters (8) 


One of the most important applications for transistors is the amplification of audio signals. The 


device providing this function is the audio amplifier or audio frequency (AF) amplifier. This might be a 


microphone preamplifier or perhaps part of a radio circuit but the result is the same: something quiet 


is made louder! 


by Burkhard Kainka (Germany) 


The principle of a (preferably) linear ampli- 
fier is straightforward: an audio signal mod- 
ulates (varies in volume and frequency) the 
small base current of a transistor, so that the 
amplified collector current produces cor- 
responding audio signals of greater inten- 
sity. The most commonly employed ampli- 
fier circuit is the emitter circuit, the name 
implying that the emitter is connected to 
the common ground potential of the cir- 
cuit. Whilst the base voltage and collec- 
tor voltage can vary, the emitter voltage 
always remains constant, namely 0 V. In cir- 
cuit diagrams we sometimes draw compo- 
nents with individual ground symbols and 
at other times a continuous ground connec 
tion, but the meaning is the same. Gener- 
ally the ground connection is joined to the 
minus (negative) pole of the current source. 


Our goal for an amplifier of this kind is to 
provide the greatest possible dynamic 
range before distortion occurs and under- 


mines the satisfyingly faithful amplification 
achieved up till then. For this reason the qui- 
escent collector current should be capped 
at just half the maximum possible current, 
with the collector resistor and supply volt- 
age selected carefully to achieve this. In this 
way the current can be varied significantly 
in either direction to an equal extent with- 
out hitting limitations. All the same, achiev- 
ing the correct quiescent current with a 
suitable base resistor is not entirely simple. 
If we take a look at Figure 1, we see here 
some optimal values for the components, 
assuming that the BC547B transistor hap- 
pens to exhibit current amplification of 
exactly 300-fold. The base current amounts 
to 


Ip =U] R=(9V-0.6V) / 560 kQ = 15 pA. 


The collector current is then Ic = Ip x V = 
15 uA x 300 = 4.5 mA. The voltage dropped 
across the collector resistor is U =/ x R = 
4.5 mA x 1 KQ = 4.5 V. The remainder of 
the 9 V, also 4.5 V as it happens, is devel- 
oped between the emitter and collector. 


This is the ideal case, in which the output 
can now be driven an equal extent in both 
directions. The voltage on the collector 
can therefore vary between 0 V and 9 V, 
meaning for example that a pure sinewave 
tone will be amplified at maximum output 
voltage without distortion. The voltage 
amplification is in this situation more than 
100-fold. 


However, if you build this circuit using a 
variety of transistors you will get a differ- 
ent result each time, because their current 
gain varies wildly. In the aworst-case sce- 
nario, a transistor might have an amplifica- 
tion factor of 600, which is so great that the 
transistor is already switched hard-on to full 
saturation. Then you can forget about get- 
ting low-distortion output signals. Fortu- 
nately there is a perfect remedy: negative 
feedback. 


Negative feedback 

The simplest form of negative feedback 
occurs when the base resistor is connected 
not to the supply voltage but to the collec 





Figure 1. Setting the bias point for exactly 300-fold gain. 
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Figure 2. Setting the bias point with negative feedback. 
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The Emitter Follower 


The emitter follower is also 
known as the common col- 
lector circuit, as the transis- 
tor operates with a constant 
collector voltage. The output 
of the amplifier is at the emit- 
ter. Every change of volt- 

age on the input is reflected 
automatically at the output 
because even a very small 
variation in the base-emitter 
voltage is sufficient to alter 
the emitter current signifi- 
cantly. The emitter voltage 





lies always around 0.6 V below the base voltage. 


A change in the base voltage of 1 V is therefore reflected in one of 
almost 1 V in the emitter voltage as well. The precise value might be 
0.99 V if a change in collector current required a variation in base- 
emitter voltage of 10 mV. The voltage amplification is thus almost 
unity (1), meaning the input voltage is not amplified even though 
the input current certainly is. The advantage of the emitter follower 
is its high input resistance or impedance. Wahilst the input resist- 
ance of an emitter follower circuit is about 1 kQ (according to its bias 
point), the collector circuit achieves 100 kQ and more. For example, 
you can connect a crystal microphone or a crystal pick-up cartridge 
direct. This circuit also lets you use a simple piezo-ceramic transduc 
er as a microphone (or for picking up sound waves in solid objects). It 
can be used like this for monitoring pulse beats for instance. 


tor (Figure 2). The rule of thumb is this: Rg 
= Re X V, where V is selected for the middle 
range of current amplification expected. For 
300-fold current amplification and a collec 
tor resistance of 1 kQ we need to use a base 
resistor of around 300 kQ. 


This time our circuit reacts ina more meas- 
ured manner to differing current gain situ- 
ations. Greater gain leads to larger collec 
tor current and therefore to greater voltage 
drop across the collector resistor. The col- 
lector-emitter voltage falls at the same time 
and with it the voltage on the base resistor 
too, which in turn leads to a reduction in 
base current. The nett result is higher gain 
offset in part by smaller base current, so 
that the collector current rises less. We call 
this negative feedback because the increase 
in collector current is counteracted. In this 
situation the negative feedback leads to 
reduced amplification but with correspond- 


DOA 


Figure 3. Stabilising the bias point. 
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ingly less distortion. Most importantly, you 
can use absolutely any NPN transistor in 
your junk box to build this circuit and it will 
work each and every time. Or expressed 
more scientifically, the circuit can tolerate 
a wide variation of samples. 


Achieving a still more accurate setting of 
the bias point calls for more effort. For this 
purpose we provide the transistor with an 
emitter resistor (Figure 3). By providing the 
base with a voltage divider we can ensure a 
fixed voltage on the base, in which the cur- 
rent flowing through the voltage divider is 
around 10 times larger than the base cur- 
rent, thus avoiding any reaction arising 
from variations in base current. The emitter 
voltage stabilises itself at a value in which 
the base-emitter voltage is below the base 
voltage. This means the emitter current 
remains stable and consequently the col- 
lector current too. 





BC547B 


In the sample circuit a base voltage of 3 V 
is given. This determines the emitter volt- 
age of 2.4 V. An emitter resistor of 1 kQ 
produces an emitter current of 2.4 mA. A 
collector resistor of 1 kQ causes a voltage 
drop of 2.4 V. The resulting collector volt- 
age is 6.6 V, along with a collector-emitter 
voltage of 4.2 V. 


The circuit displays a strong relationship 
between voltage and negative feedback. 
A small variation in the emitter voltage has 
a direct effect on the base-emitter voltage 
and, on account of the steep characteris- 
tic curve of the base, leads to a significant 
change in the collector and emitter cur- 
rents. Since only very small variations in 
base-emitter voltage are desired, the emit- 
ter voltage is set at a value that is always 
about 0.6 V below the base voltage. The 
function resembles that of the so-called 
emitter follower (see panel). 





BC547B 


Figure 4. A two-stage audio amplifier. 
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An audio millivoltmeter 





An audio millivoltmeter would be very handy for investigating the 
amplifiers described here. The A-D converter in the ATtiny13 can in 
fact measure only DC voltages. All the same, by elevating the mean 
voltage to 2.5 V and making rapid measurements, AC voltages can 
be investigated as well. The result is sent serially to the PC and can 
then be displayed using a terminal program. 


The principle of the measurement program is straightforward. First 


+5V 


ATtiny13 


PB3 PB4 






1mV...2V 100n itd 


we determine the mean voltage by averaging. There then follows 

a rapid series of multiple individual measurements, from which the 
mean voltage is subtracted, creating an absolute value for each in- 
stance. The smallest measurable voltage step for the A-D converter 
is actually 5 mV. Even so, by averaging many separate readings we 
can get down to 1 mV. In the actual measurement loop process we 
carry out, process and add up 2,780 readings. Incidentally, the read- 
ing points are entirely asynchronous with regard to the test signal. 
However, the large number of test measurements made and the ran- 
dom factor combine to produce an adequate result, so long as the 
input signal remains between roughly 50 Hz and 50 kHz. 


How do we arrive at this ominous figure of 2,780? This figure is 
based on a reference voltage of 5 V and takes into account the dif- 
ference between arithmetic averaging and true RMS measurement, 
so that the result in the case of a sinusoidal signal is displayed as 
actual effective values in MVerr. In order to determine accurate rms 
(root-mean-square) values, you would have to actually add up the 
square of the voltage and afterwards calculate the mean value from 
the square root. This would overwhelm the ATtiny13, however. For 
this reason we derive the arithmetic mean from the absolute volt- 
age. This is around 10% too low, or more precisely by a factor of the 


root of 2 divided by pi / 2, i.e. 0.9003. One A-D step is 5000 mV / 
1023 = 4.8876 mV. In addition the measured value is multiplied by 8 
and then divided by 4096, thus effectively dividing by 512. In order 
to display everything correctly in mV, we need to multiply by 512 x 
4.8876 | 0.9003 = 2780, and this is simplified when 2,780 measure- 
ments are totalled. 


The result is remarkably accurate. Even values like 1 or 2 MVor are 
displayed stably! 


‘Millivoltmeter 1 mVeff ... 2000 mVeff 
$regfile = “attiny13.dat” 

$crystal = 1200000 

$hwstack = 8 

$swstack = 4 


$framesize = 4 


Dim U1 As Integer 
Dim U2 As Integer 
Dim U3 As Long 

Dim N As Integer 


Config Adc = Single , Prescaler = Auto 
Start Adc 
Open “comb.1:9600,8,n,1,INVERTED” For Output As #1 


Do 
U2 = ð 
For N= 1 To 64 
U1 = Getadc(3) 
U2 = U2 + Ul 
Next N 
Shift U2 , Right , 3 ‘ /8 
U3 = Qð ‘ zero point 
For N= 1 To 2780 
U1 = Getadc(3) 
Shift U1 , Left, 3 48 
Ul = U1 - U2 
U1 = Abs(U1) 
U3 = U3 + Ul 
Next N < x 2780 
Shift U3 , Right , 12 ‘ / 4096 
Print #1 , U3 
Loop 
End 


In principle a harsh level of negative feed- 
back has the disadvantage of much reduced 
voltage amplification. To achieve adequate 
amplification of audio signals we need to 
boost the negative feedback for AC cur- 
rents, specifically by using an emitter capac 
itor. Its value is determined by the lowest 
frequency being handled, without skimping 
(avoid using too small a value). 
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Two stages 

If the level of amplification provided by a 
single transistor is insufficient, a multi-stage 
amplifier will be required. Figure 4 shows a 
version with two stages and R-C coupling. 
In most situations the simple form of neg- 
ative feedback, with one resistor between 
base and collector, will be entirely adequate 
for obtaining an appropriate bias point. The 


circuit also demonstrates a further prin- 
ciple of amplifier development: from left 
to right, the circuit becomes successively 
lower in impedance. In this way we achieve 
high input resistance and low output resist- 
ance. The latter would not be up to connect- 
ing a loudspeaker but with headphones 
on the output, it would be fine for many 
applications. 
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Figure 5. A two-stage audio amplifier with DC coupling. 


DC-coupled stages 

Multi-stage audio amplifiers can be created 
at reduced cost if you forego capacitor cou- 
pling between the individual stages and 
employ DC coupling instead. The collector 
resistor of the first transistor is now simul- 
taneously the base resistor of the second 
one (Figure 5). Frequently this also simpli- 
fies setting the bias point, with the base cur- 
rent being appropriate for both transistors. 
Figure 5 shows a two-stage, directly cou- 
pled amplifier. The base current of the first 
transistor is branched off from the emitter 
of the second stage. This provides negative 
feedback and stabilisation of the bias point. 
The voltage drop across the relatively small 
base resistor of 100 kQ can be disregarded 
and consequently the emitter voltage at the 
second transistor amounts to around 0.6 V. 
In the process the emitter resistor of 330 Q 
determines the emitter and collector cur- 
rents of the second stage, which are largely 
independent of the supply voltage. 


The negative feedback should not lead to 
any reduction in AC voltage amplification. 
An additional emitter capacitor takes care 
of ensuring that only DC current is fed back. 
In practice the amplifier has a low frequency 
limit that can be set even lower with a larger 
emitter capacitor. 


Three stages 

The position is even simpler with a three- 
stage amplifier because negative feedback 
can be applied direct from the output to the 
input (Figure 6). Each stage reverses the 
signal phase by 180 degrees. With a two- 
stage amplifier we needed a flip-flop to 
achieve feedback. On the other hand, one 
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or three stages produce negative feedback, 
which stabilises the bias point. 


Figure 6 shows a circuit optimised for small 
supply voltages from 1 V upwards. Here, as 
in Figure 2, we see how greater amplifica- 
tion in the transistors leads to increased 
collector current flow in the third transis- 
tor and hence to larger voltage drop across 
its collector resistor. The collector-emitter 
voltage falls and consequently also the volt- 
age dropped across the two 100 kQ nega- 
tive feedback resistors. This results finally 
in reduced base current, as explained pre- 
viously above. 
The collector-emitter voltage here amounts 
consistently to merely 0.6 V or so, ena- 
bling each stage to deliver relatively mod- 
est amounts of audio amplification. All the 
same, this is more than compensated by the 
high number of amplifier stages. 
The negative feedback element of the cir- 
cuit includes a low-pass filter with a capaci- 
tor to ground (bypass capacitor), which 
boosts the negative feedback for higher 
frequencies. It is essential for achieving high 
levels of audio amplification. The circuit is, 
for example, ideal as a sensitive microphone 
preamplifier or as audio amplifier in simple 
radio receivers. A headset can be connected 
directly in place of the collector resistor in 
the third stage. Incidentally the circuit was 
used in the ‘Tapir’ RF Sniffer described in the 
Elektor July & August 2012 edition (www. 
elektor.com/120354). 

(120008) 
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Figure 6. A three-stage, direct-coupled amplifier. 
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3x 
BC547B 


Quiz solution from 


the June 2012 edition 


The correct solution code is ‘CDG’. Here 
is how it is worked: 


Solution 1: 


The LED drops around 1.8 V, with Uce at the 
transistor about 0.1 V. This leaves 7.1 V 
over. 1 kQ and 470 Q form a voltage di- 
vider of around 3.1:1. 7.1 V/3.1=2.3 V 
(Solution C). 


Solution 2: 


For the left-hand transistor to start conduct- 
ing its base voltage must be around 0.6 V 
above the emitter voltage, hence 2.3 V + 
0.6 V = 2.9 V. The correct solution is D. 


Solution 3: 


If the right-hand transistor is fully cut off 
and the left-hand one is hard on, we will 
find approx. 9V/11=0.8 V at the emitter 
resistor. This gives a base-emitter voltage 
of 0.6 V, which the left-hand transistor 
requires to conduct. Therefore the lower 
switching point lies around 1.4 V (G). 
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How about making 


your next project speak? 


By Christian Picard (France) 


When your attention is occupied elsewhere, it’s sometimes impossible to 
watch a display — to keep an eye on a changing value, for example. Here’s just 
one example: you’re keenly watching your favourite R/C model, on the ground 
or in the air, which just happens to be fitted with telemetry. Now wouldn’t it 
would be a great idea if you could keep track of its speed or altitude, or the 


drive battery voltage, just by listening. What do you say to that? 


Module description 
The voice of the whole thing comes from a module by 4D Systems, 
the SOMO-14D [1], which is capable of reading files from a micro SD 
memory card of 2 GB maximum. The module’s audio output can be 
to a speaker or headset. 


As for the brain of this project, that’s an Atmega8AU microcon- 
troller, clocked by an 8 MHz crystal, whose mission is to drive the 
sound module that is going to perform the voice playback of the 
number or message analysed. The sound module is driven via a 
2-wire (data and clock) serial connection, managed by the micro- 
controller which receives its own orders as a slave on the BC bus. 


This circuit will be connected to the BC bus of an application 
and will make it possible, for example, to read out loud a string 
of ASCII characters representing a whole or floating-point num- 
ber, positive or negative, resulting from a calculation and stored 
in a ‘string’ variable. 


It is possible to use the SOMO module directly within an application 
by using the 2-wire bus —- for example, just for playing sound files — 
but this would tie up the main program and memory space, which 
may be at a premium in any case if the microcontroller is being used 
in ‘lean’ mode! A further advantage of the unit described here is its 
transportability to another application. 


Firmware 

The microcontroller’s main program consists of little more than a 
wait loop that analyses the string received as soon as the whole of 
the l2C data frame has been decoded. Within this loop, the received 
characters trigger an interrupt per character. The program will 
leave the loop at the end of the string, indicated by the ‘null’ char- 
acter $00, followed by two hex characters representing the num- 
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sixty three. 


volts 4 


ber (name) of the file in the micro SD card containing the units of 
the measurement value that has just been read out (or any other 
message). 

Some clarification may be in order here. Let’s suppose that the num- 
ber to be read out is -235.12 V. The ASCII data string to be transmit- 
ted is assembled as follows (hexadecimal): $2d $32 $33 $35 $2c $31 
$32 $00 $00 $69. Now you'll have recognized the minus sign in the 
character $2d and the comma, $2c. I’m sure you’ve followed the 
rest, except perhaps for the last two. Remember, there’s a unit to 
be read now: ‘volt’. In point of fact, $00 $69 (= 105 in decimal) is the 
number of the file “volt” on the micro SD card. Note that this applies 
to the author’s own files — it may well have a different number in 
your system, since it’s up to you to record your own sound files. 


Returning to the analysis, the first check is to determine if the 
received string corresponds to a number or a direct address to the 
SOMO-14D module. If the first character received is the null charac 
ter ($00), the program treats the next two hex bytes as a file num- 
ber and this file is read. If the first character is not the null charac 
ter, the string is taken as an ASCII representation of a number. In 
this case, the programme looks to see if it is a whole number, a 
decimal, positive or negative, how many digits before the decimal 
point, how many after it (1, 2, or 3 digits maximum), etc. These lat- 
ter elements will determine which of the various subroutines will be 
called. Among the bytes received that are neither numbers nor file 
numbers, there may be direct commands to the sound module, for 
example adjusting the volume ($FF $FO to $FF $F7). 


A minor adaptation will be necessary for using English (or other lan- 
guages), just for the numbers. For example, the specific differences 
between the French and English language way of expressing “hun- 
dreds” (FR: cent, EN: one hundred) and “thousands” (FR: mille, EN: 
one thousand). Also, the decimal point should replace the comma. 
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It’s a subtle point, but does justify a slight modification in the 
structure of the software. 





To note... 

- Leading non-significant zeroes in the string will be suppressed. 
— If the string starts with a zero (ASCII $30), the number will be 
interpreted as being less than one and a maximum of three digits 
after the decimal point will be read. 
- When a number is zero, the string will be $30 $00. 
— For a number with no units, the null character at the end of the 
string will be followed by $C0, so no unit will be spoken and the 
sound display will be stopped. 


A few examples (after adaptation to English) 

12 will be read out as “twelve”. 

527 will be read out as “five hundred twenty-seven”. 

13,689,222 will be read out as “thirteen million six hundred eighty- 
nine thousand two hundred twenty-two”. 

0.155 will be read out as “zero point one hundred fifty-five” 
-0.155 will be read out as “minus zero point one hundred fifty-five” 


Circuit 

The project circuit diagram is shown in Figure 1. The module is rela- 
tively compact (25 x 40 mm) and should be easy to fit into applica- 
tions. Constructing the board takes a bit of dexterity, but not too 
much. Manual soldering of the ATmega8AU (SMD type in a TQFP32 
package) is made easier by using solder paste, the same as is used 
for reflow soldering. Here’s the method I use: the IC is positioned 
accurately and held in place using a spring clip, then a moderate 
amount of paste is applied to the IC pins. A fine-tipped soldering 
iron will do the job with no risk of bridging between pins. 

There’s space for an HE6 socket to allow the microcontroller to be 
programmed. 

A few resistors and capacitors in SMD packages are required. The two 
1N4001 diodes (D2 and D3) are recommended by the manufacturer 
to allow the sound module to be powered from 5 V (rated at 3.3 V). 
The module can be soldered directly into the board, or mounted by 
means of IDC socket strips. 

The output at J9 is intended to drive a speaker or headset of 8, 16, 
or 32 Q; the sound module is capable of supplying up to 250 mW. 
D4, a3 mm LED, shows when the SOMO module is busy. 
Communication with the BC bus can be achieved by hard-wiring or 
SIL strip connectors. 


The pin assignments for J11 are as follows: 
Pin Function 
not connected 
vv 
OV 
SCL 
SDA 
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GND GND XTAL1 XTAL2 AGND 
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Figure 1. Circuit diagram for the Vocal Annunciator. 


Everything’s stored in the micro SD card 

The memory contains the files required for making up numbers and 
messages. The relatively high capacity of the micro SD memory, 
2 GB maximum, means it can be used in various different fields. 
Around 105 files are needed to produce numbers in French. So 
that leaves the user with 407 files that can contain various units, 
words, phrases, music, alarm messages for the widest range of 
applications. 


PC commands 

The module’s address is $58. The access protocol is standard, a 
START followed by the module address, then the data representing 
the characters of the string to be processed, ending with a STOP 
command. 

| haven’t tested all the direct commands. The command for setting 
the volume has been validated, along with the direct addressing of 
the sound files. 
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The main components of the Vocal Annunciator. 


SOMO-14D commands according to the manufacturer’s data. 


Command code | Function | Deseripton 


Addresses one of the pre- 
recorded audio/sound/voice files 
in the micro SD e card 
(from 0 to 512 files max.) 


Audio file 


0000h - 01FFh 
number 


Code f tting th | 8 
FFFOh = FFF7h volue ode for setting the volume, 

levels in all. 

Plays or pauses the current audio 
FFFEh Play/pause Ad P 


Stops playing of the current audio 
FFFFh Stop file and puts the module into idle 
mode. 


File details 

The elementary files in French used by the analysis program may be 
downloaded from [2] - they are all ready for loading into a micro 
SD card. However, users can create their own messages and the ele- 
mentary files can be replaced by these user files. 

The elementary files represent the figures from “zero” to “hundred”, 
“thousand” (0101d), “mega” (0144d), “comma” (0129d), “point” 
(0130d) and “minus” (0102d). Because of the requirements of the 
software, the figures from 0 to 99 will occupy files 0 to 99, which 
will be converted into hex characters by the software in order to 
address the sound module. This behaviour only applies to the part 
involving the reading of the numbers, since as explained above, the 
direct message commands will be sent in hex. 

The voices used can be synthesized or recorded live. The only vital 
point is that recordings must have a minimum length in order for 
them to be recognized, as the SOMO module will simply ignore files 
that are too short. 

You can download a free utility (SOMO Tool) [3] from the manufac- 
turer’s website, which lets you convert .wav or .mp3 sound files into 
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The assembled circuit. 


.ad4, the only format the SOMO module can recognize. 

The manufacturer warns that certain micro SD cards are not suita- 
ble. The author uses SanDisk cards, which up till now I’ve found per- 
fectly satisfactory, as long as you respect the minimum file length. 


(110465) 


Internet links 
[1] SOMO module: www.4dsystems.com.au/prod.php?id=73 


[2] Software and author’s sound files (in French): 
www.elektor.com/110465 


[3] SOMO audio converter utility: 
www.4dsystems.com.au/prod.php?id=74 





For small circuits, fitting a programming connector can be 
awkward. To get round this problem, the author has created this 
programming device. 
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Fascinated by technology’s impact on 
the future? 
Check out Tech the Future! 


Computing power and global 
interconnectivity are pushing tech 
innovation into overdrive. 

Pioneering technologies and creative 
workarounds affect even the couch 
potato 24/7. Tech the Future reports 
on technology strides that shape 

the future — yours included. 


www.techthefuture.com 
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Design > simulate > Download 


Flowcode is one of the World’s most advanced 
graphical programming languages for micro- 
controllers (PIC, AVR, ARM and dsPIC/PIC24). 
The great advantage of Flowcode is that it allows iy . 
those with little experience to create complex elec- Convince yourself. 


tronic systems in minutes. Flowcode’s graphical = en aa R Demo version, further 

development interface allows users to construct a sn information and ordering at 
complete electronic system on-screen, develop a ne ee 
program based on standard flow charts, simulate WWW.eCreKtor.com/Tiowcode 
the system and then produce hex code for PIC 
AVR, ARM and dsPIC/PIC24 microcontrollers. 




















Flowcode, 
for AW 




















By Ivo Pullens (The Netherlands) 


A number of years ago Intel created a spec- 
ification for 4-wire PWM driven PC fans 
(see [1]). These fans are hardly more expen- 
sive than the well-known 2-pin and 3-pin 
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varieties, although they have the advantage 
that their rotational speed can be controlled 
using a PWM signal. The 3-pin and 4-pin 
connectors also include a tachometer signal 
that can be used to feed the instantaneous 
speed of the fan back to the motherboard. 
A PC motherboard often has only a single 


fan connector that includes a PWM signal, 
although a PC usually contains several fans. 
There is no choice but to run these other 
fans at a fixed speed. And even if there is a 
facility to connect several PWM fans, it usu- 
ally isn’t possible to control them individu- 
ally from the motherboard. 
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The circuit described here is capable of con- 
trolling the speed of up to six fans in a PC 
in a safe and flexible manner, so that they 
will run at their minimum required speed 
and hence keep the noise level as low as 
possible. 


The circuit 

It can be seen from the circuit diagram 
in Figure 1 that the circuit itself is very 
straightforward. It consists of not much 


more than an Atmega microcontroller and 
a number of connectors for connecting the 
fans, sensors, USB and power supply. The 
4-wire fans are connected directly to the 
microcontroller, since they are able to cope 
with the generated PWM signals without 
any further processing. The internal pull- 
ups of the microcontroller make sure that 
the open-collector tachometer signals from 
the fans are pulled towards the positive sup- 
ply voltage. 


COMPUTERS 


R3/C2 is a low-pass filter that smoothes 
(integrates) the incoming PWM signal 
from the motherboard, so that an ana- 
logue input of the microcontroller can be 
used to read the PWM control signal from 
the motherboard. 


For the analogue temperature sensors you 
can use two 10 kQ NTC sensors, which are 
connected to K11 and K12. Together with 
the NTCs, R8 and R9 form two potential 








SENSE_IN 


100n 





LOW PASS, 16Hz 


12C TEMP SENSOR 





TEMP_ANO 


10k NTC CONNECTORS 


1 TACHO4/MISO l 








CONNECTOR 














vcc AVCC 
PDO(RXD/PCINT16) 
PD1(TXD/PCINT17) 
PD2(INTO/PCINT18) 
PD3(INT1/OC2B/PCINT19) 
PD4(T0/XCK/PCINT20) 
PD5(T1/OCOB/PCINT21) 
PD6(AINO/OCOA/PCINT22) 
IC1 PD7(AIN1/PCINT23) 

ATMEGA(168PA-PU 
PB0(ICP1/CLKO/PCINTO) 
PB1(OC1A/PCINT1) 
PB2(SS/OC1B/PCINT2) 
PB3(MOSI/OC2A/PCINT3) 
PB4(MISO/PCINT4) 
PB4(SCK/PCINT5) 


PCO(ADCO/PCINTS8) 
PC1(ADC1/PCINT9) 
PC2(ADC2/PCINT10) 
PC3(ADC3/PCINT11) 
PC4(ADC4/PCINT12) 
PC5(ADCS5/PCINT13) 
PC6(RESET/PCINT 14) 


PB6 


PB7 
GND XTAL1 XTAL2 AGND 











Figure 1. The circuit consists mainly of an Atmega microcontroller and a large number of connectors. 
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Resistors 

R1,R2 =68Q 

R3 = 100kQ 
R4,R8,R9 = 10kQ 
R5=1.5kQ 
R6,R7 =4.7kQ 
R10-R15 = 1kQ 


Capacitors 

C1 = 10uF 16V radial, lead pitch 2.5mm 
C2,C5,C6 = 100nf, lead pitch 5mm 
C3,C4 = 22pF 


Semiconductors 

D1,D2 = 3.6V zener diode, 400 mW 

IC1 = ATmega168PA-PU, programmed, 
Elektor # 100160-41 





Miscellaneous 

X1 = 16MHz quartz crystal 

J1 = 3-pin pinheader with jumper 
K1-K6,K7 = 4-pin fan header 

K8 = 4-pin PC supply plug, PCB mount 
K9 = Mini USB-B connector, PCB mount 
K10 = 4-pin pinheader 

K11,K12 = 2-pin pinheader 

K13 = 6-pin (2x3) boxheader 

PCB # 100160-1 [3] 
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Figure 2. With this PCB the construction of the circuit becomes child’s play! 





dividers that are connected to ADC2 and 
ADC3 of the microcontroller. 

If you wish, you can connect a maximum of 
eight I2C temperature sensors to K10. R6 
and R7 are the required pull-ups on the bus. 
The firmware has been tested with Micro- 
chip MCP980x sensors, but similar sen- 
sors such as the TCN75 should work either 
directly or with a small modification. When 
the firmware starts it figures out itself how 
many sensors are connected to the I2C bus. 
Jumper J1 is used to select either the USB 
bus or the PC as the source of the power 
supply for the microcontroller. During 
firmware development, when no fans are 
connected, it can be convenient to power 
the circuit via the USB bus, but normally 
the PC supply would be used (jumper on 
pins 2 and 3). 


Construction 

Since the circuit doesn’t have any SMDs the 
construction is quite easy, especially if you 
use the PCB designed for this project (Fig- 
ure 2). The large connector (K8) is the male 
version of the well-known PC hard drive 
connector, made by Molex. If required, the 
power supply cable could also be soldered 
directly to the board. 

The official 4-pin fan headers (K1 to K7) may 
be difficult to get hold of in small quantities. 
The 3-pin version, however, is much more 
widely available. The form and connec 
tions of both connectors are identical, so 
that 3-wire fans can be connected to 4-pin 
headers. Conversely, if you mount a 3-pin 
fan header and in the space for the fourth 
pin mount a single header pin you end up 
with the equivalent of a 4-pin header (see 
Figure 3). This makes it easy to connect 
PWM fans without the risk of connecting 
them the wrong way. 


Firmware 

The software for the microcontroller is writ- 
ten in Cand makes use of a software-based 
USB stack V-Usb (see [2]) to communicate 
with a PC. The software was initially devel- 
oped for an ATmega88, but this was soon 
found to be too small to accommodate al 
the functions it was required to perform. 
For this reason we changed over to the 
ATmega168, which has double the amount 
of flash memory. However, it is still possible 
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e Autonomous individual control of up to six 4-wire PWM fans. 
e Measurement of the rotational speed of these fans and detection 


of stalled fans. 


e Support for a maximum of 8 sensors to control the fan speed: 


- 2 NICs 


- 2C temperature sensors, MCP980x/TCN75 compatible 
- Rotational speed of fans can also be used as a ‘sensor’ signal 
- External ‘sensors’, where the value can be set via USB 


- The duty-cycle of an external fan control signal, such as 


emanating from a motherboard 


to compile the software for the ATmega88, 
although with a reduced functionality (refer 
to the file config.h in the download available 
from the Elektor website [3]). 

As mentioned in the Intel specification for 
4-wire fans, they should be controlled with 
a PWM signal with a frequency of about 
25 kHz, where the rotational speed should 
follow the duty cycle linearly from 20% 
upwards (at lower duty cycles the speed is 
undefined). The ATmega contains six PWM 
outputs, but only two of these (which are 
driven by the 16-bit Timer1) can be set to 
exactly 25 kHz. The other PWM outputs 
are driven by 8-bit timers and can be set to 
either 7.8 kHz or 62.5 kHz. A little trick is 
used to make them operate at the required 
frequency. They are set to operate at the 
lower frequency of 7.8 kHz, but then the 
overflow interrupt of Timer1 is used to 
restart the 8-bit timers, which causes all 
PWM outputs to operate at 25 kHz. 


The pulses from the tachometers, which 
are used to measure the rotational speed of 
the fans, are counted using the pin-change 
interrupt. In practice the fans rarely went 
faster than 6000 revolutions per minute, 
where the tachometer outputs two pulses 
per revolution. When all fans run at full 
speed this means that the software has 
to deal with about 1200 pin-change inter- 
rupts per second. This may seem like a lot, 
but the main loop is quite simple which 
leaves plenty of time for calculating the 
duty cycles. 


This main loop checks every second if any of 
the fans has stopped, for example because 
of a fault or obstruction. Depending on the 
settings, a stalled fan can cause the simu- 
lated tachometer signal to stop, thereby 
signalling to the motherboard that a fan 
has stopped. Any function on the mother- 
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- Constant 


e The rotational speed can be set in three ways: 


- Linear control where the rotational speed 


depends ona sensor signal 


- Pl-controlled that uses a sensor signal and 


a required sensor value to calculate the rotational speed 


e Configuration and monitoring via USB. 
e Software library for use in PC applications to let you 
communicate with the circuit and a PC application to configure 


and drive the circuit, for Windows as well as Linux. 





Figure 3. With the addition of an extra pin 
you can use a 3-pin fan header 
to make up a 4-pin connector for a 
PWM controlled fan. 


board that raises an alarm when a fan fails 
will therefore continue to work. 

Next, the current sensor values are read, all 
the calculations are carried out and the val- 
ues for the duty-cycles are written into the 
output-compare registers for the timers. 
The interval of one second for calculating 
the new duty cycles may seem like quite a 
long time in the world of microcontrollers, 
but it is quite suitable for controlling a slow- 
changing process such as the temperature 
inside a PC. 


The simulated tachometer signal for the 
motherboard has to be able to provide a 
maximum of about 1200 pulses per sec 
ond, where the timing doesn’t have to be 
that accurate. For this reason the pulses are 
generated from the main loop, where the 


tachometer pin is made to go alternately in 
a low state and a high-impedance state in 
order to reproduce the required open-col- 
lector output. 

With the help of the PC software the cur- 
rent configuration for the controller can 
be stored in the EEPROM, so that it can be 
automatically loaded when the circuit is 
turned on again. 

A large part of the software consists of the 
USB stack and the routines for exchanging 
messages with the PC. The ‘realtime’ com- 
munication with the PC is taken care of by 
the INTO handler, which has the highest 
priority. 


Software 

The PC software has been written in C++ 
and was developed using the free Micro- 
soft Visual C++ 2010 Express. The graphi- 
cal interface makes use of wxWidgets, 
which means that it can be used both 
under Windows as well as Linux (and OS 
X too, but this has not been tested in prac 
tice by the author). 

LibUsb has been used to communicate 
with the circuit via a USB link. A sepa- 
rate library has been used for the creation 
and exchange of messages. This hides the 
details of the communication between the 
PC and the circuit and promotes the re-use 
of the routines. From here you can directly 
set the rotational speed of fans or read the 
sensor values. 

The graphical interface consists of the fol- 
lowing tabs: 


e Admin 

Here you can manage the EEPROM, such 
as reading or writing the configuration. 
Remember to store a good configuration 
into the EEPROM at the first opportunity, 
otherwise the circuit will have a blank con- 
figuration when it restarts! 
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Figure 4. A screendump of the associated PC program that is used for the 
configuration and monitoring of the fans. 


e Sensor0 to 7 

The sensor tabs let you assign the con- 
nected sensors to a sensor input and inspect 
their value graphically over time. 

e Fan0to5 

Here you can configure the individual fans. 


e Fan out 
This is used to configure the simulated 
tachometer signal to the motherboard. 


Before a sensor can be used as a controller in 
the circuit it needs to be assigned to a sen- 
sor input. 


Figure 4 shows an example of the configu- 
ration for Fan 0, which is connected to K1. 
At the top-left the type of fan (so the soft- 


ware knows if a tachometer and/or PWM 
signal can be used) and the type of con- 
trol can be selected. In this example the I2C 
sensor with address 0 (Temp_I2C_Addr0) 
measures the temperature of the outside 
air that is sucked into the PC case and the 
sensor with address 7 (Temp_I2C_Addr7) 
measures the temperature inside the case 
itself. Since the PC generates heat itself, it 
would be unrealistic to expect to get the 
inside temperature the same as the out- 
side temperature. The controller will there- 
fore be configured such that the inside tem- 
perature will be at most 2 °C higher than the 
outside temperature (the setting +2 after 
the setpoint). The PI (Proportional-Integral) 
control selected here continuously calcu- 
lates the difference between the required 


temperature (outside temperature +2 °C) 
and the measured inside temperature. The 
controller will increase the rotational speed 
of the fan proportionally (using factor Kp) 
and also take account of integrating errors 
over time (factor Ki). 

In the figure you can see that the fan starts 
of slowly at a duty-cycle of 0%. When the 
inside temperature increases (the dark blue 
line) above the required temperature (the 
light blue line), the controller ensures that 
the rotational speed of the fan increases 
(the green line, in revolutions per second). 
When the required temperature has been 
reached again after some time the rota- 
tional speed gradually decreases. 


Another possible application for this circuit 
is to synchronise the speed of several fans 
in order to keep vibrations in the PC case to 
a minimum. To do this, use a PI controller 
with the rotational speed of one fan as the 
sensor for all other fans and negative factors 
for Kp and Ki. 

On the final tab you can configure the 
source for the simulated tachometer sig- 
nal to the motherboard, such as the fan 
with the lowest rotational speed or a copy 
of one of the connected fans. For each fan 
a minimum required rotational speed can 
be specified. If it falls below this limit the 
software considers that the fan has stalled 
and the simulated tachometer signal to the 
motherboard will be stopped. 


In the Elektor download [3] you will find 
both the firmware for the microcontroller 
as well as the PC software. 

(100160) 
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Ivo Pullens is a freelancer who has specialised in embedded 
software development. 


He recently worked on a large industrial assignment for the Internet Links 
production of semi-conductors and the industrial fieldbus. 


[1] www.formfactors.org/developer/ 
In his infrequent spare time he develops solutions to every- 


specs/4_Wire_PWM_Spec.pdf 
day problems, usually based on microcontrollers. 
[2] www.obdev.at/products/vusb/ 


More information can be found on his website index.html 


(in Dutch only): www.emmission.nl 
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DESIGN TIP 


Current Transformers 


Professional current transformers often use toroidal cores and are wound to high precision. The purpose 


of this article is to demonstrate how to make your own current transformers for projects, using readily 


available parts. This will allow safe, isolated measurements of current in power supply conductors. 








Figure 1. Current transformer with 
secondary winding on bobbin. 


By Ed Dinning (United Kingdom) 


Current transformers (CTs), as their name 
implies, transform a high current to a 
smaller one (usually) for metering and con- 
trol purposes. They also provide isolation 
between primary and secondary windings; 
as such they are used extensively in the 
power infrastructure. Their great advan- 
tage over more modern devices such as 
Hall effect and Rogowski coils is that they 
are self powered and will operate meters 


RL 





Figure 2. Current transformer with primary 
winding added. 


and protective relays without additional 
supplies. 


Setting up parameters 

As with all transformer designs, it is cus- 
tomary to define the load, or burden, as 
it is mostly also known. For most profes- 
sional CTs this is usually no greater than 
10 VA (loads are often expressed in VA 
rather than watts due to phase shifts 
being involved; this is not really a con- 
cern in the simple designs we introduce 
in this article). 








Figure 3. Completed and laminated current 
transformer. 


For the purposes of this design we will be 
driving a meter or feeding a comparator 
as part of a protective circuit and a load of 
0.5 VA will be sufficient. 


We will assume that we wish to monitor the 
current in a circuit with a maximum value 
of 10 A, and that we want to lower this to 
50 mA, i.e. a 200:1 ratio. 


With a 0.5 VA load and 50 mA of current we 
calculate a voltage of 10 V (U =P | I) anda 
resistive load value of 200 ohms (R =U] I). 


T € 
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tie 
miele 
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110323 - 11 


110323 - 12 





Figure 4. Test circuit for our self wound transformer. Figure 5. ACT ina circuit with a moving coil meter. 
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We need to calculate the secondary turns 
required to go on the transformer. For this 
application we will use a small transformer 
that has a core area of, say 300 to 400 mm2. 
These can be obtained cheaply and even 
recovered from old equipment. The larger 
the core area, the fewer turns that will be 
required. 

Many commercial transformer laminations 
are classified with an El number. We are 
using an El48 (long dimension of lamina- 
tions equals 48 mm) by a 20 mm stack. The 
centre leg of the lamination is 16 mm wide, 
and with a stack of 20 mm of these the area 
works out at: 


0.016 x 0.02 = 0.00032 m2. 
We then use the transformer equation: 
N=E| (4.44 fBA,) 


where N is the number of turns, E the 
applied voltage, f the system frequency, B 
the flux density in Tesla and A, the cross- 
sectional area of the core in square metres. 
The AC line frequency is 50 Hz (US: 60 Hz). 
It is common to operate at the relatively low 
flux density of 0.2 Tesla (unlike a voltage/ 
power transformer operating at >1 Tesla, 
depending on lamination material). Enter- 
ing these values into the equation gives: 


N= 10 | (4.44 x 50 x 0.2 x 0.00032) 
N = 704 turns (US: N = 586 turns) 


We’re rounding this of to 700 turns. We 
know we need a turns ratio of 200 to 1, 
so we would need to use a 3.5 turn pri- 
mary (US: 2.93). This is not practical, so we 
increase secondary turns to 800 (US: 600) 
(giving a lower flux density and greater 
accuracy) and use a 4 turn primary (US: 3 
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turns). Now we have the theory sorted. On 
to the practicalities of winding. 


Winding the core 

The secondary is to carry 50 mA. It is nor- 
mal to work at 3 A/mm? with copper wire. 
Working backwards this gives a 0.15 mm 
diameter wire (approx.), i.e. 0.16 mm 
(#34 AWG) including its enamel coating. 
The transformer bobbin winding area is 
20 mm wide and 6 mm deep. This will allow 
125 turns per layer and 6.4 layers (rounded 
to 7); or a winding depth of 1.2 mm, leav- 
ing a space of 4.8 mm for the primary. See 
Figure 1. 


Note that the primary is made from one 
core of 10 A rated mains cable, either flex- 
ible or solid core, see Figure 2. The primary 
insulation is provided by the insulation on 
this wire. Four turns are added on top of 
the secondary and the windings are held 
in place with an insulating tape (polyester 
transformer tape is best suited for this). The 
transformer is then laminated with alter- 
nate ‘E’ & ‘I’ laminations, so that there is 
virtually no air gap, see Figure 3. 


The unit can now be tested using the cir- 
cuit shown in Figure 4. Note that the load 
resistor (R,) must always be connected, or 
the windings can go short-circuit, as current 
transformers develop very high voltages 
when run into an open circuit. A DVM in its 
AC current range can be used to measure 
the secondary voltage. Its internal imped- 
ance relative to the load determines the 
deviation: the lower the internal imped- 
ance, the better. 


Example #2 

A more practical use of a CT is to drive a 
moving coil meter through a rectifier, like 
in the circuit shown in Figure 5. A moving 


17.22 EURO’ 


5 pcbs, 100mmk 100 mm 


CURRENT TRANSFORMERS 


coil meter typically has a full-scale deflec 
tion of 1 mA; if this is used in parallel with 
the load (carrying 50 mA), it will make lit- 
tle difference to the accuracy of the system. 
As can be seen from the circuit, the trans- 
former develops a maximum of 10 volts 
across the load resistor when 10 A are flow- 
ing in the primary. If this voltage is fed into 
a bridge rectifier, we can read a DC voltage 
across the output of the bridge. 


When the 1 mA meter is connected across 
this DC output, it can be calibrated to read 
AC amps when a series resistor (Rc) is used. 
Ohms law tells us that the resistor should 
have a value of 10 kQ minus the internal 
resistance of the meter (typically 100 Q or 
less). If the 10 kQ resistor is made variable, 
the meter can be accurately calibrated. 


Any vibration of the meter pointer can be 
dampened with a small capacitor across the 
bridge output. 0.1 uF should be sufficient. 
Higher values will cause the meter to ‘peak 
read’ and have a longer response time. 


If the meter is accurately calibrated, it will 
be found to be non-linear near the bottom 
of the scale. To some extent this is due to 
the forward voltage loss of the bridge recti- 
fier diodes. The use of Schottky or Ge (ger- 
manium) diodes here will reduce this effect. 
The design can also be extended to switch 
mode and audio circuits to measure cur- 
rent; the use of a ferrite transformer is rec 
ommended where the frequency is above 
about 1 kHz to reduce losses. With a ferrite 
the flux density should be reduced to about 
25 mT to maintain accuracy. 


(110323) 
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Marconi Instruments 
TF801D/1 AM RF Signal Generator 


“They don’t make ‘m like that anymore” 


By Stephan Germann (Switzerland) 


Manufactured by UK-based Marconi Instruments, the type 
TF801D/1 is an RF generator covering frequencies from 10 MHz 
to 470 MHz. Built at around 1960, the instrument is likely to have 
been pretty expensive if only for its highly complicated mechanical 
assembly. | got this generator ‘thrown in’ when | bought a second- 
spectrum analyser about 15 years ago. Since then, it has provided 
steady service in my workshop set up for the construction or repair 
of amateur radio transceivers. The electrical data are also very good 
by today’s standards, the only weak point being the frequency sta- 
bility, which of course cannot compete with a DDS Generator. With 
some patience and skills though, even an SSB receiver for the 2 m 
band can be checked. 


|I am using this equipment for adjusting and checking amateur 
radio equipment, as well as for troubleshooting, not forgetting 
tuning checks on homemade antennas, filters and matching 
networks. Thanks to the continuous frequency range, amateur 
bands from 30 m to 70 cms are catered for, as well as all the regu- 
lar intermediate frequencies (IFs). The very large output voltage 
range from 100 nV to 1 V enables both sensitive receivers to be 
checked, and driver stages of transmitters or passive impedance 
measuring bridges to be driven. Thanks to vacuum tube tech- 
nology, the equipment is electrically very robust. The precision 
of the output voltage and the total absence of RF leakage never 
cease to amaze me. The operation too is very convenient when 


compared with today’s devices. In fact, it beats many of today’s 
menu-driven controls, or jog-style rotary controls with multiple 
functions, mainly because each function has its own button, and 
superfluous functions are absent. 


Barring one defective electrolytic capacitor, no repairs were nec 
essary, clearly pointing to the use of superb quality components. 
The pots for example are wound from resistance wire and sealed 
tightly. The modulation depth and RF output voltage each have their 
own moving coil meter on the front panel. The controls are spa- 
ciously arranged over the front panel, and all controls and knobs are 
of ‘comfortable’ size. The frequency scale is so large and accurate 
that tuning to less than 100 kHz error is possible up in the UHF fre- 
quency range without additional measuring equipment. The drive 
assembly is accurate, and fine-tuning is also provided. 


The construction of the TF801D is marked by extreme stability, 
which becomes manifest if you lift all 30 kgs (66 Ibs) of it. UK-made, 
the unit has imperial screws and bolts only. The internal structure 
consists of a sturdy chassis, on which the modulator, the control 
circuit and the power supply are constructed. Attached to it is the 
RF section in a RF sealed double casing made of silver plated copper 
sheet. The external RF housing only contains the tuning mechanism 
as well as the RF filters for passing the control voltage. The RF cir- 
cuitry itself is located in an internal RF-proof housing that’s divided 
into two parts for the oscillator and the final stage. Thanks to this 
method of construction RF voltage appears at the output jack only; 
in other places it is simply not detectable, which is a feat when con- 
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sidering both the oscillator and the RF power amplifier have an RF 
power capability of the order of 100 mW. 


The circuit itself consists of ten tubes, a couple of semiconductor 
diodes and a single Germanium transistor (OC71), and is not terribly 
exciting from today’s perspective. Sections of the circuit diagram 
are reproduced here, due to their size they cannot be printed in full. 
The power supply consists of a transformer, a 5R4GY full-wave recti- 
fier tube and a voltage stabiliser comprising a 5651 reference tube, 
an EF95 (6AK5W) control amp and a KT66 audio output tube as the 
regulating element. The filament voltage for the oscillator tube is 
stabilised with a transductor (current-controlled inductance). 

The RF signal is generated ‘straight off’, i.e. the oscillator oscillates 
at the desired frequency (= sig gen output frequency) and its output 
signal is buffered by an RF tetrode. The oscillator employs a TD03- 
100 UHF triode with five switchable coils around it for the frequency 
ranges. It is tuned with a variable capacitor. Unusually a heat sink is 
found attached to the anode terminal of the triode. 

The oscillator signal directly drives the symmetrical push-pull out- 
put stage built around a QQVO02-6 UHF dual tetrode. The tube oper- 
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ates in class A, resulting in maximum gain and low distortion (hence, 
low harmonics). The DC level at the control grids allows the gain to 
be controlled, or amplitude modulated if required. Thanks to the 
gain control, the output voltage is independent of load as well as 
frequency, making the measuring and matching of filters very con- 
venient indeed. 

The anode circuit of the amplifier also comprises five switchable 
coils. Together with a second variable capacitor, the coils act as 
tuneable resonant circuits tuned in synchronism with the oscillator. 
To prevent tracking errors, the variable capacitor of the output cir- 
cuit can be slightly detuned with respect to the oscillator — mechan- 
ically, a not so simple design. The linear amplification afforded by 
the push-pull output stage keeps harmonics generation down to a 
minimum. The output signal is inductively coupled out through the 
attenuator having a single calibrated range of 135 dB, and providing 
a resistor network for a frequency-independent, rock steady output 
impedance of 50 ohms. 


The 5-position frequency range selection switch is also worth men- 
tioning. Remarkably, the switch does not work as expected from 
one marker to the next (to get to the next frequency range), but 
requires an additional full turn. The switch itself is contactless, the 
connection with the coils being capacitive. This has the advantage 
of avoiding contact problems, which is highly relevant in view of the 
tuned circuits’ Q (quality) factors. 


Besides the everyday use of the instrument, the manual describes 
maintenance and common repair steps in great detail, both 
mechanical (like Bowden cable replacement) and electrical. | espe- 
cially liked one tip for faultfinding: “Initially, look for burnt resistors 
to locate a faulty circuit section”. 

(120169) 


Retronics is a monthly section in Elektor magazine covering 

vintage electronics including legendary Elektor projects. 
Contributions, suggestions and requests are welcomed; please send an 
email to Jan Buiting (editor@elektor.com). 
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INFOTAINMENT 


Hexadoku 
Puzzle with an electronics touch 


Past page 75 or thereabouts and fed up with all that designing, programming and soldering? Then take a 
break deservedly and give this puzzle a go. Enter the right numbers or letters A-F in the open boxes, find 


the solution in the grey boxes, send it to us and you automatically enter the prize draw for one of four 


Elektor Shop vouchers. 


The instructions for this puzzle are straightforward. Fully geared to 
electronics fans and programmers, the Hexadoku puzzle employs 
the hexadecimal range 0 through F. In the diagram composed of 
16 x 16 boxes, enter numbers such that all hexadecimal numbers 
0 through F (that’s 0-9 and A-F) occur once only in each row, once 


Solve Hexadoku and win! 


Correct solutions received from the entire Elektor readership automati- 
cally enter a prize draw for one Elektor Shop voucher worth £80.00 and 
three Elektor Shop Vouchers worth £40.00 each, which should encour- 
age all Elektor readers to participate. 


in each column and in each of the 4x4 boxes (marked by the thicker 
black lines). A number of clues are given in the puzzle and these 
determine the start situation. Correct entries received enter a draw 
for a main prize and three lesser prizes. All you need to do is send us 
the numbers in the grey boxes. 


Before November 1, 2012, 
send your solution (the numbers in the grey boxes) by email to: 


hexadoku@elektor.com 


Prize winners 
The solution of the July & August 2012 Penta-Hexadoku is: D89276. 
The Elektor £80.00 voucher has been awarded to Norbert Breuker (Germany). 
The Elektor £40.00 vouchers have been awarded to Donald Hoogendorp (Netherlands), 
Jean-Marie Bellet (France), and Mike Parker (United Kingdom). 
Congratulations everyone! 
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The competition is not open to employees of Elektor International Media, its business partners and/or associated publishing houses. 
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Comprehensive reading: at home and on the road 





Join now or upgrade: www.elektor.com/member 
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NEW 


More than 75,000 components 


i CD Elektor’s 


Components Database 7 
This CD-ROM gives you easy access to design data 
for over 11,100 ICs, 37,000 transistors, FETs, thy- 
ristors and triacs, 25,100 diodes and 2,000 opto- 
couplers. The program package consists of eight 
databanks covering ICs, transistors, diodes and op- 
tocouplers. A further eleven applications cover the 
calculation of, for example, zener diode series resis- 
tors, voltage regulators, voltage dividers and AMV’s. 
A colour band decoder is included for determining 
resistor and inductor values. All databank applica- 
tions are fully interactive, allowing the user to add, 
edit and complete component data. 

ISBN 978-90-5381-298-3 e £24.90 e US $40.20 


A whole year of Elektor magazine 
onto a single disk 


2 DVD Elektor 2011 


The year volume DVD/CD-ROMs are among the most 
popular items in Elektor’s product range. This DVD-ROM 
contains all editorial articles published in Volume 2011 
of the English, American, Spanish, Dutch, French and 
German editions of Elektor. Using the supplied Adobe 
Reader program, articles are presented in the same lay- 
out as originally found in the magazine. An extensive 
search machine is available to locate keywords in any 
article. With this DVD you can also produce hard copy 
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Limited Time Offer for Elektor Magazine Members! 


20% DISCOUNT 


www.elektor.com/october 


of PCB layouts at printer resolution, and export circuit 
diagrams and illustrations to other programs. 
ISBN 978-90-5381-276-1 e £23.50 e US $37.90 


LabWorxX 2 

Mastering Surface 

Mount Technology 

This book takes you on a crash course in techniques, 
tips and know-how to successfully introduce sur- 
face mount technology in your workflow. Even if you 
are on a budget you too can jumpstart your designs 
with advanced fine pitch parts. Besides explaining 
methodology and equipment, attention is given to 
SMT parts technologies and soldering methods. Many 
practical tips and tricks are disclosed that bring sur- 
face mount technology into everyone's reach with- 
out breaking the bank. A comprehensive kit of parts 
comprising all SMT components, circuit boards and 
solder stencils is available for readers wishing to rep- 
licate three projects described in this book. 

282 pages e ISBN 978-1-907920-12-7 

£29.50 e US $47.60 


Elektor Linux Board 

Embedded Linux 

Made Easy 

Today Linux can be found running on all sorts of de- 


vices, even coffee machines. Many electronics enthu- 
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siasts will be keen to use Linux as the basis of a new 
microcontroller project, but the apparent complexity 
of the operating system and the high price of de- 
velopment boards has been a hurdle. Here Elektor 
solves both these problems, with a beginners’ course 
accompanied by a compact and inexpensive popula- 
ted and tested circuit board. This board includes eve- 
rything necessary for a modern embedded project: 
a USB interface, an SD card connection and various 
other expansion options. It is also easy to hook the 
board up to an Ethernet network. 

Populated and tested Elektor Linux Board 


Art.# 120026-91 e £57.80 e US $93.30 


A comprehensive and practical 
how-to guide 


Design your own PC 
Visual Processing 
and Recognition 
System in C# 


This book is aimed at Engineers, Scientists and en- 
thusiasts with developed programming skills or with 
a strong interest in image processing technology on 
a PC. Written using Microsoft C# and utilizing ob- 
ject-oriented practices, this book is a comprehen- 
sive and practical how-to guide. The key focus is on 


modern image processing techniques with useful 
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and practical application examples to produce high- 
quality image processing software. Analysis starts 
with a detailed review of the fundamentals of im- 
age processing. It progresses to explain and explore 
the prac tical uses of two highly sophisticated and 
freely downloadable, open source image processing 
libraries; AForge.NET and Emgu.CV, utilizing dotnet 
technology within the Microsoft Visual Studio envi- 
ronment. All code examples used are available — free 
of charge - from the Elektor website; you can easily 
create and develop your own results to demonstrate 
the concepts and techniques explained. 

307 pages e ISBN 978-1-907920-09-7 

£35.50 « US $57.30 


Free Software CD-ROM included 
Elementary Course 
BASCOM-AVR 

The Atmel AVR family of microcontrollers are ex- 
tremely versatile and widely used. In Elektor maga- 
zine we have already published many interesting 
applications employing an ATmega or ATtiny micro- 
controller. The majority of these projects perform a 
particular function. In this book we focus more on the 
software aspects. Using lots of practical examples we 
show how, using BASCOM, you can quickly get your 
own design ideas up and running in silicon. 

224 pages e ISBN 978-1-907920-11-0 

£34.95 e US $56.40 
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BOOKS, CD-ROMs, DVDs, KITS & MODULES 


Ultrasensitive wideband E-smog detector 
TAPIR Sniffs it Out! 

Attention boy scouts, professionals and grandfathers! 
This ultrasensitive wideband E-smog detector offers 
you two extra senses to track down noise that’s nor- 
mally inaudible. TAPIR — short for Totally Archaic 
but Practical Interceptor of Radiation — also makes 
a nice project to build: the kit comprises everything 
you need. Even the enclosure, ingeniously consist- 
ing of the PCB proper! Using the TAPIR is dead easy. 
Connect the headphones and an antenna and switch 
it on. Move it around any electrical device and you'll 
hear different noises with each device, depending on 
the type and frequency of the emitted field. 

Kit of parts, incl. PCB 

Art.# 120354-71 e £13.30 e US $21.50 


Circuits, ideas, tips and tricks 

CD 1001 Circuits 

This CD-ROM contains more than 1000 circuits, ide- 
as, tips and tricks from the Summer Circuits issues 
2001-2010 of Elektor, supplemented with various 
other small projects, including all circuit diagrams, 
descriptions, component lists and full-sized layouts. 
The articles are grouped alphabetically in nine dif- 
ferent sections: audio & video, computer & micro- 
controller, hobby & modelling, home & garden, high 


frequency, power supply, robotics, test & measure- 
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ment and of course a section miscellaneous for eve- 
rything that didn’t fit in one of the other sections. 
ISBN 978-1-907920-06-6 e £34.50 e US $55.70 


Package Deal: 12% off 
AVR Software 
Defined Radio 


This package consists of the three boards associated 
with the AVR Software Defined Radio articles series in 
Elektor, which is built around practical experiments. 
The first board, which includes an ATtiny2313, a 20 
MHz oscillator and an R-2R DAC, will be used to make 
a signal generator. The second board will fish signals 
out of the ether. It contains all the hardware needed 
to make a digital software-defi ned radio (SDR), with 
an RS-232 interface, an LCD panel, and a 20 MHz 
VCXO (voltage-controlled crystal oscillator), which 
can be locked to a reference signal. The third board 
provides an active ferrite antenna. 

Signal Generator + Universal Receiver +Active 
Antenna: PCBs and all components + USB-FT232R 
breakout-board 


Art.# 100182-72 e £99.90 e US $133.00 


Avoid interference and earth loops 

USB Isolator 

If your USB device ever suffers from noise caused 
by an earth loop or if you want to protect your PC 
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against external voltages then you need a USB iso- 
lator. The circuit described in Elektor’s October 2012 
edition offers an optimal electrical isolation of both 
the data lines as well as the supply lines between the 
PC and the USB device. 

Populated and tested Board 

Art.# 120291-91 e £62.30 e US $101.40 


Associated 60-piece Starter Kit available 


1 Fun with LEDs 
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This booklet presents more than twenty exciting 
projects covering LEDs, aimed at young & old. From 
an Air Writer, a Party Light, Running Lights, a LED 
Fader right up to a Christmas Tree. Use this book to 
replicate various projects and then put them into 
practice. To give you a head start each project is 
supported by a brief explanation, schematics and 
photos. In addition, the free support page on the 
Elektor website has a few inspiring video links avail- 
able that elaborate on the projects. A couple of pro- 
jects employ the popular Arduino microcontroller 
board that’s graced by a galaxy of open source ap- 
plications. The optional 60-piece Starter Kit avail- 
able with this book is a great way to get circuits 
built up and tested on a breadboard, i.e. without 
soldering. 

96 pages e ISBN 978-1-907920-05-9 

£16.95 e US $38.00 
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Free mikroC compiler CD-ROM included 
Controller Area 

Network Projects 

The aim of the book is to teach you the basic prin- 
ciples of CAN networks and in addition the develop- 
ment of microcontroller based projects using the 
CAN bus. You will learn how to design microcontroller 
based CAN bus nodes, build a CAN bus, develop high- 
level programs, and then exchange data in real-time 
over the bus. You will also learn how to build micro- 
controller hardware and interface it to LEDs, LCDs, 
and A/D converters. 

260 pages e ISBN 978-1-907920-04-2 

£29.50 e US $47.60 


Bridging Android and your electronics projects 
AndroPod 

With their high-resolution touchscreens, ample com- 
puting power, WLAN support and telephone func- 
tions, Android smartphones and tablets are ideal for 
use as control centres in your own projects. However, 
up to now it has been rather difficult to connect them 
to exter-nal circuitry. Our AndroPod interface board, 
which adds a serial TTL port and an RS485 port to the 
picture, changes this situation. 

Andropod module with RS485 Extension 

Art.# 110405-91 e £53.35 èe US $74.70 
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Meet BOB 
FT232R USB/ 
Serial Bridge/BOB 


You'll be surprised first and foremost by the size of this 
USB/serial converter - no larger than the moulded plug 
on a USB cable! And you're also bound to appreciate 
that fact that it’s practical, quick to implement, reus- 
able, and multi-platform — and yet for all that, not too 
expensive! Maybe you don’t think much of the various 
commercially-available FT232R-based modules. Too ex- 
pensive, too bulky, badly designed, That’s why this pro- 
ject got designed in the form of a breakout board (BOB). 
PCB, assembled and tested 


Art.# 110553-91 e £12.90 e US $20.90 


110 issues, more than 2,100 articles 


“DVD Elektor 


1990 through 1999 

This DVD-ROM contains the full range of 1990-1999 
volumes (all 110 issues) of Elektor Electronics maga- 
zine (PDF). The more than 2,100 separate articles 
have been classified chronologically by their dates of 
publication (month/year), but are also listed alpha- 
betically by topic. A comprehensive index enables 
you to search the entire DVD. What's more, this DVD 
also contains the entire ‘The Elektor Datasheet Col- 
lection 1...5’ CD-ROM series. 

ISBN 978-0-905705-76-7 e £69.00 e US $111.30 
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Enhanced second edition 

Design your own 
Embedded Linux 

Control Centre on a PC 

The main system described in this book reuses an 
old PC, a wireless mains outlet with three switches 
and one controller, and a USB webcam. All this is 
linked together by Linux. This book will serve up the 
basics of setting up a Linux environment — including 
a software development environment — so it can be 
used as a control centre. The book will also guide 
you through the necessary setup and configuration 
of a webserver. New edition enhancements include 
details of extending the capabilities of your control 
center with ports for a mobile phone (for SMS mes- 
Saging) and the Elektor “thermo snake” for lowcost 


networked real-time thermal monitoring of your ~~ 


house and outbuildings. Now you can additionally 
also send all kinds of useful temperature and sensor 
warnings to a mobile phone. All software needed will 
be available at the Elektor website. 

416 pages e ISBN 978-1-907920-02-8 

£34.50 e US $55.70 


Processor design in the real world 
Microprocessor Design 
using Verilog HDL 

If you have the right tools, designing a microproces- 
sor shouldn't be complicated. The Verilog hardware 
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description language (HDL) is one such tool. This 
book is a practical guide to processor design in the 
real world. It presents the Verilog HDL in an easily digest- 
ible fashion and serves as a thorough introduction about 
reducing a computer architecture and instruction set 
to practice. You're led through the microprocessor de- 
sign process from the start to finish, and essential topics 
ranging from writing in Verilog to debugging and tes- 
ting are laid bare. 

340 pages e ISBN 978-0-9630133-5-4 

£27.90 e US $45.00 


Counter for alpha, beta and 

gamma radiation 

Improved 

Radiation Meter 

This device can be used with different sensors to meas- 
ure gamma and alpha radiation. It is particularly suit- 
able for long-term measurements and for examining 
weakly radio-active samples. The photodiode has a 
smaller sensitive area than a Geiger-Muller tube and so 
has a lower background count rate, which in turn means 
that the radiation from a small sample is easier to de- 
tect against the background. A further advantage of a 
semiconductor sensor is that is offers the possibility of 
measuring the energy of each particle. 

Kit of parts incl. display and programmed controller 


Art.# 110538-71 e £35.50 e $57.30 
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Dual-layer DVD: 165 mins. video 


19 DVD Modern Valve 


Electronics 

This filmed seminar (presented by Menno van der 
Veen) starts with a short discussion of the classic ap- 
proach using valve load line graphs, followed by cur- 
rent sources and current foldback techniques. Next, 
the negative effect of cathode electrolytics is covered 
as well as reducing supply voltage interference. With 
the help of state of the art measurement techniques 
the (in)correctness of feedback is proven, while also 
clarifying what's happening deep within the core of 
the output transformer. 

ISBN 978-1-907920-10-3 e £24.90 e US $40.20 


More information on the 
Elektor Website: 
www.elektor.com/store 
Elektor 

78 York Street 

London - W1iH 1DP 

United Kingdom 

Tel.: +44 20 7692 8344 

Email: order@elektor.com 
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COMING ATTRACTIONS NEXT MONTH IN ELEKTOR 


Nixie VU Meter 


After various Nixie clocks, thermometers and a hygrometer, a Nixie VU meter gets 
described in Elektor next month. This circuit is designed to embellish a (tube) amplifier. It 
supplies beautiful light effects but it is not calibrated to represent instantaneous output 
power in any exact way. At the heart of the circuit is a Cypress PSoC type CY8C27443, 
which determines the level of two audio channels and looks after the driving of two Rus- 
sian Nixie tubes type IN-G. 


Elektor FPGA Board 


ini peeves. | Always wanted to start working with FPGAs, but found nothing but hindrances in your 
da i way? Elektor now has a great option for you: an affordable FPGA developer’s board that’s 
= = zii a easy to use, as well as to extend by way of a standard breadboard. The microcontroller on 
RE the board takes care of the communicating with the PC via USB, while the configuration 
;lecupuuasaaaabe ss: data for the FPGA are stored on a micro-SD card located on the board too. Using Windows 
a configuration file can easily be transferred on to the SD card; when the card is reset this 

configuration file gets written into the FPGA. 


= 
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Cool! 7805 Drop-in 


The 7805 is unquestionably the most widely used fixed voltage regulator. Unfortunately 
this golden oldie has a habit of turning all the excess energy into heat. Wouldn’t it be nice 
to have a switching power supply controller as a drop-in replacement for the 7805? The 
switched device is sure to offer much higher efficiency as well as better specifications. In 
the Elektor labs, a small printed circuit board was designed around a TPS62150 buck con- 
verter capable of turning an input voltage of 5.5 to17 V into a 5 V stabilized rail at up to1A. 
By adjusting a number of resistance values, other output voltages are also possible. 

(we are sorry this article could not be published in the October 2012 edition as planned) 





Article titles and magazine contents subject to change; please check the Magazine tab on www. elektor. com 


Elektor UK/European October 2012 edition on sale October 18, 20712. Flektor USA October 2012 edition published October 15, 2012. 
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Elektor on the web 


All magazine articles back to volume 2000 are available individually in pdf format against e-credits. Article summaries and compo- 
nent lists (if applicable) can be instantly viewed to help you positively identify an article. Article related items and resources are also 
shown, including software downloads, hyperlinks, circuit boards, programmed ICs and corrections and updates if applicable. 

In the Elektor Shop you’ll find all other products sold by the 
publishers, like CD-ROMs, DVDs, kits, modules, equipment, 


tools and books. A powerful search function allows you to 
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search for items and references across the entire website. 


Also on the Elektor website: 
e Electronics news and Elektor announcements 


part 
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e Readers Forum 
e PCB, software and e-magazine downloads 
e Time limited offers 








e FAQ, Author Guidelines and Contact nem <0 O E PLOWCODES 
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ORDERING INSTRUCTIONS, P&P CHARGES 


Non-online orders, except for memberships (for which see below), must be sent BY POST or FAX to 
Elektor International Media, 78 York Street, London W1H 1DP, United Kingdom. 

Online ordering: www.elektor.com/store 

Orders placed on our London office must include P&P charges (Priority or Standard) as follows: 
Europe: £6.00 (Standard) or £7.00 (Priority). Outside Europe: £9.00 (Standard) or £11.00 (Priority) 


HOW TO PAY 


All orders must be accompanied by the full payment, including postage and packing charges as stated above or advised by Customer Services staff. 

Bank transfer into account no. 40270211 held by Elektor International Media BV with The Royal Bank of Scotland, London. 

IBAN: GB96 ABNA 4050 3040 2702 11. BIC: ABNAGB2L. Currency: sterling (UKP). 

Please ensure your full name and address gets communicated to us. 

Cheque sent by post, made payable to Elektor Electronics. We can only accept sterling cheques and bank drafts from UK-resident customers or members. 
We regret that no cheques can be accepted from customers or members in any other country. 

Credit card VISA and MasterCard can be processed by mail, email, web, fax and telephone. Online ordering through our website is SSL-protected for your 
security. 


COMPONENTS 


If difficulties are envisaged in the supply of components for Elektor projects, a source will normally be advised in the article. 
Note, however, that the source(s) given is (are) not exclusive. 


TERMS OF BUSINESS 


Delivery Although every effort will be made to dispatch your order within 2-3 weeks from receipt of your instructions, we can not guarantee this time 
scale for all orders. 


Returns Faulty goods or goods sent in error may be returned for replacement or refund, but not before obtaining our consent. All goods returned should 
be packed securely in a padded bag or box, enclosing a covering letter stating the dispatch note number. If the goods are returned because of a mistake on 
our part, we will refund the return postage. 


Damaged goods Claims for damaged goods must be received at our London office within 10 days (UK); 14 days (Europe) or 21 days (all other countries). 
Cancelled orders All cancelled orders will be subject to a 10% handling charge with a minimum charge of £5.00. 
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ROUTE FASTER ! 
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Our completely new manual router makes placing tracks quick and intuitive. During track 
placement the route will follow the mouse wherever possible and will intelligently move 
around obstacles while obeying the design rules. 


All versions of Proteus also include an integrated world class shape based auto-router as 


standard. 


PROTEUS DESIGN SUITE Features: 


= Hardware Accelerated Performance. 
= Unique Thru-View™ Board Transparency. = 
= Over 35k Schematic & PCB library parts. = 
= Integrated Shape Based Auto-router. a 
= Flexible Design Rule Management. 5 
= Polygonal and Split Power Plane Support. 


Board Autoplacement 4 Gateswap Optimiser. 
Direct CADCAM, ODB++, IDF & PDF Output. 
Integrated 3D Viewer with 3DS and DXF export. 
Mixed Mode SPICE Simulation Engine. 
Co-Simulation of PIC, AVR, 8051 and ARM. 
Direct Technical Support at no additional cost. 
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